XML扩展标记语言

1.xml的作用:
  1_在没有真正数据库的前提下,当作小型的数据库用
  2_在服务端创建XML文件,以IO形式将XML文件传递给客户端,客户端拿到后,提取出XML文件中
    有用的内容,进行处理
  3_软件配置,如:JavaEE应用中WEB-INF/web.xml文件
2.XML的基本语法
  一个XML文件,加载到内存后,会形成一个倒状的树结构,
  XML文件内容越多,耗用的内存也就越大
  1_文档声明
    就是XML文件中第一行代码:
    <?xml version="1.0" encoding="UTF-8"?>
    version="1.0"表示解析XML时,采用的版本号
                 XML可以浏览器来解析,因为浏览器内置XML解析器,让浏览器采用XML1.0
                 版本的解析器来解析,目前1.0最为常用
    encoding="UTF-8"表示解析XML时,采用什么样的解码方式
            在Eclipse中,该属性也表示保存该文件时采用的编码方式 
    注意:文档声明前不要有空行,空格,注释
  2_元素/标签/节点
    通常情况下,标签有开始,就有结束,
    如果标签无文本的话,可以简写,如<a/>
    但不能乱套,大小写敏感
    HTML可以乱套,大小写不敏感 
    元素名称做到见名知意,
    HTML标签是有含意的,如<b>在HTML中表示粗体,但在XML中只是一个标签而以
  3_属性
    是对标签的附加的说明,只出现在开始标签中
  4_注释
    给程序员看,XML解析器忽略
    不能嵌套
  5_CDATA字符数据段/区
    让XML不按照XML本身的语法来约束,即不将<符合看作是标签的一个部份,而就不报错了
  6_转义字符
    用特殊的字符替代XML中敏感的内容
    <-----&lt;  less than
    >-----&gt;  greater than
    赵君个人觉得:程序代码在正确情况下:清晰性->移植性->封装性(一个方法只做一件事)->
                 -->时(间快)空(间少)性
  7_处理指令
结合CSS技术,可以读取XML文件的内容,并显示在浏览器
3.XML的约束模式
  用于约束XML如何书写的一种技术,这个技术就叫约束模式
  约束模式有二个大类别:
  1-DTD,易学易用,采用DTD语法,功能有限
  2-Schema,相对难学难用,采用XML语法,功能强大
4.DTD简介
  DTD不能独立存在,必须嵌入到XML中才有效
  嵌入方式有二大类
  1_内部方式:DTD和XML在同一个XML文件中
  2_外部方式:DTD和XML在不同的文件中,一个在XML中,一个在DTD中,最后通过<!DOCTYPE语句嵌入在一起
    -------01:引用外部本地的DTD,即DTD文件就在你的PC上
       <!DOCTYPE 根标签 SYSTEM "DTD文件的路径">

    -------02:引用外部远程的DTD,即DTD文件不在你的PC上
       <!DOCTYPE 根标签 PUBLIC "DTD名称" "DTD文件的路径">
           如:html4这个版本,所有html4程序员,都要遵循loose.dtd这个约束规则
  <!ELEMENT元素定义
  <!ATTLIST属性定义
  <!ENTITY实体定义,就是用一个普通的变量,代替一个文本字符串
5.XML解析介绍
  提取XML文件中对应用有用的数据的过程叫XML解析 
  有二大类解析方式:
  1-DOM[Document Object Model]方式
特点:一次性将XML文件,由硬盘加载到内存,形成一倒状树结构
    优点:速度快,从顶向下解析
    缺点:费内存
W3C组件推荐
  2-SAX[Simple Api for Xml]方式:
    特点:【不是】一次性将XML文件加载到内存,无倒状树结构
      而是多次加载
    优点:不费内存
    缺点:相对费时
6.DOM4J解析XML
/**
 * 用DOM解析方式中的DOM4J解析器来解析src/tv.xml文件
 */
public class Demo02 {
    public static void main(String[] args) throws Exception{
        InputStream is = Demo02.class.getClassLoader().getResourceAsStream("tv.xml");
        SAXReader saxReader = new SAXReader();
        Document xmlDocument = saxReader.read(is);
        Element rootElement = xmlDocument.getRootElement();

        //如果dom4j获取较多层次的标签内容时,非常麻烦
        String tv = rootElement.element("a").element("b").element("c").element("d").getText().trim();
        System.out.println(tv);
    }
}
7.XPath的使用

是结合dom4j一起使用的技术,xpath能够根据字符串,快速定位符合条件的标签
Element dElement = (Element) xmlDocument.selectSingleNode(xpath);
List list = xmlDocument.selectNodes(xpath);

/**
     * 判断用户是否存在
     * @param  name  用户名
     * @param  sex   性别
     * @param  age   年龄 
     * @return true  存在
     * @return false 不存在
     */
    public boolean exists(String name,String sex,int age) throws Exception{
        boolean flag = false;
        InputStream is = this.getClass().getClassLoader().getResourceAsStream("classs.xml");
        SAXReader saxReader = new SAXReader();
        Document xmlDocument = saxReader.read(is);
        //String xpath = "/classs/student[@name='班长' and @sex='男' and @age>22]";
        String xpath = "//student[@name='"+name+"' and @sex='"+sex+"' and @age>"+age+"]";
        Element element = (Element) xmlDocument.selectSingleNode(xpath);
        //如果返回值非空,表示找到了
        if(element!=null){
            flag = true;
        }else{
            ;
        }
        return flag;
    }

总结:XML语言应用广泛 ,既可以做小型数据库,也可以用来传输数据,还可以用来书写配置文件,而太灵活的属性xml不利于对其信息的提取,因而对其进行了DTD或者Schema约束便于解析,解析用到的方法之一就是DOM4J或者SAX,当DOM4J 与xpath 联合使用时可以快速查询所需要的元素.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值