首頁  >  文章  >  後端開發  >  帶你深入了解XML

帶你深入了解XML

Y2J
Y2J原創
2017-04-26 10:12:081501瀏覽

1、XML : extensible markup language 可擴展標記語言version="1.0"

  • 可擴充:所有的標籤都是自訂的

  • 功能:資料儲存

    • 設定檔

    • #資料傳輸

  • html 與xml 區別

    • HTML語法鬆散,xml語法嚴格

    • html做頁面展示,xml做數據儲存

    • Html所有標籤都是預先定義的,xml所有標籤都是自訂的

##2、xml語法:

  • 文件宣告

    • 文件聲明
    • version 版本號固定值1.0
    • encoding 指定文檔的碼表預設值為iso-8859-1
    • standalone 指定文件是否獨立yes 或no
    • ##必須寫在xml文件的第一行
    • 寫法:41d1bdbe64b863f2b16c14c0adc44b32
  • 屬性

    • 元素xml文件中的標籤

    • 元素名稱區分大小寫
    • 數字不能開頭
    • 文件中必須有且只能有一個根元素
    • 元素需要正確閉合6c04bd5ca3fcae76e30b72ad730ca86d36cc49f0c466276486e50c850b7e4956 c5fe2e2ca8878824fae07a69295aad51
    • 轉義字元>
  • ##CDATA 裡邊的資料會原樣顯示

    • 屬性

  • 屬性值必須用引號引起來,單雙引號都行

    • 註解

  • #19791207a4e0a22c816ac020ecd8cae0

    • 處理指令:現在基本上不用

8492057e916c54ee353cd8d3d9f11f4f

  • 3、XML約束

  • 約束約束就是xml的書寫規則

    • 約束的分類:

    • 導入xsd約束文件

    • 寫根標籤

    • #引入實例名稱空間 xmlns:xsi="www.w3.org/2001/XMLSchema-instance"

    • 引入名稱空間 xsi:schemaLocation="www.itcast.cn/ xml student.xsd"

    • 引入預設的名稱空間

    • #student.xsd

    • student .xml
    • <?xml version="1.0"?>
      <xsd:schema xmlns="www.itheima.cn/xml"
              xmlns:xsd="www.w3.org/2001/XMLSchema"
              targetNamespace="www.itheima.cn/xml" elementFormDefault="qualified">
          <xsd:element name="students" type="studentsType"/>
          <xsd:complexType name="studentsType">
              <xsd:sequence>
                  <xsd:element name="student" type="studentType" minOccurs="0" maxOccurs="unbounded"/>
              </xsd:sequence>
          </xsd:complexType>
          <xsd:complexType name="studentType">
              <xsd:sequence>
                  <xsd:element name="name" type="xsd:string"/>
                  <xsd:element name="age" type="ageType" />
                  <xsd:element name="sex" type="sexType" />
              </xsd:sequence>
              <xsd:attribute name="number" type="numberType" use="required"/>
          </xsd:complexType>
          <xsd:simpleType name="sexType">
              <xsd:restriction base="xsd:string">
                  <xsd:enumeration value="male"/>
                  <xsd:enumeration value="female"/>
              </xsd:restriction>
          </xsd:simpleType>
          <xsd:simpleType name="ageType">
              <xsd:restriction base="xsd:integer">
                  <xsd:minInclusive value="0"/>
                  <xsd:maxInclusive value="256"/>
              </xsd:restriction>
          </xsd:simpleType>
          <xsd:simpleType name="numberType">
              <xsd:restriction base="xsd:string">
                  <xsd:pattern value="itheima_\d{4}"/>
              </xsd:restriction>
          </xsd:simpleType>
      </xsd:schema>
      <?xml version="1.0" encoding="UTF-8" ?>
    • fd69e2b1a3ca3c3f40e9955c3fd64af8

    • ## -->
    • <students
          xmlns="www.itheima.cn/xml"
          xsi:schemaLocation="www.itheima.cn/xml student.xsd"
          xmlns:xsi="www.w3.org/2001/XMLSchema-instance"
      >
          <student number="itheima_1001">
              <name>asfd</name>
              <age>12</age>
              <sex>male</sex>
          </student>
      </students>
      <students
          xmlns:itheima="www.itheima.cn/xml"
          xsi:schemaLocation="www.itheima.cn/xml student.xsd"
          xmlns:xsi="www.w3.org/2001/XMLSchema-instance"
      >
          <itheima:student number="itheima_1001">
              <itheima:name>asfd</itheima:name>
              <itheima:age>12</itheima:age>
              <theima:sex>male</itheima:sex>
          </itheima:student>
      </itheima:students>
    • 內部dtd 在xml內部定義dtd

    • #外部dtd 在外部檔案中定義dtd

    • Student.dtd

    • student.xml

    • 本地dtd檔a5dfb9c8da626e491c0e8e2104dc79df
    • 網路dtd檔4b401ec346e5d916afe941370e4279f8
    • ##

      <!ELEMENT students (student*) >
      <!ELEMENT student (name,age,sex)>
      <!ELEMENT name (#PCDATA)>
      <!ELEMENT age (#PCDATA)>
      <!ELEMENT sex (#PCDATA)>
      <!ATTLIST student number ID #REQUIRED> 唯一的,必须的
      <?xml version="1.0" encoding="UTF-8" ?>
      <!DOCTYPE students SYSTEM  "student.dtd">
      <students>
          <student number="s0001" >
              <name>zs</name>
              <age>abc</age>
              <sex>yao</sex>
          </student>
      </students>

    #dtd  約束不嚴謹

    schema
    • #4、XML解析
    • 解析XML可以做:
    如果xml作為設定檔:讀取
  • #如果xml作為傳輸檔案:寫、讀
    • XML解析思想:
    • #優點:不佔內存,速度快

    • #缺點:只能讀取,不能回寫

    • 優點:因為記憶體中會形成dom樹,可以對dom樹進行增刪改查

    • #缺點:dom樹非常佔內存,解析速度慢

    • Document Element Text Attribute Comment

    DOM:將文件加載到內存,形成一棵dom樹(document物件),將文件的各個組成部分封裝為一些物件
  • SAX:逐行讀取,基於事件驅動
    • xml常用的解析器
    • 定義了一種規則

    • 使用方法

    • 使用步驟
    • XPath:
    • public classTestXPath2 {
            @Test
            publicvoidtest()throwsException{
                  SAXReaderread= new SAXReader();
                  Documentdocument= read.read("src/Dom4jTest.xml");
                  Listnodes= document.selectNodes("/bookstore//book/title");
                  for(inti= 0;i< nodes.size();i++) {
                        Nodenode= (Node)nodes.get(i);
                        System.out.println(node.getText());
                  }
            }
      }

    • selectSingleNode()

      ######selectNodes()############注意:要導引包jaxen...jar####
    • 创建解析器 SAXReader reader = new SAXReader()

    • 解析xml 获得document对象 Document document = reader.read(url)

    •         //    nodename 选取此节点。

    •         //    /     从根节点选取。

    •         //    //     从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置。

    •         //    ..     选取当前节点的父节点。

    •         //    @     选取属性。

    •         //      [@属性名]    属性过滤

    •         //      [标签名]     子元素过滤

    •       @Test

            //遍历所有元素节点

    •  publicvoidtest2()throwsException{
                  //创建一个xml解析对象
                  SAXReaderreader= new SAXReader();
                  //把xml文档加载到document对象中
                  Documentdocument= reader.read("src/Book.xml");
                  Elementroot= document.getRootElement();
                  treeWalk(root);
            }
            
            privatevoidtreeWalk(Elementele){
                  //输出当前节点的名字
                  System.out.println(ele.getName());
                  //ele.nodeCount()得到当前节点的所有子节点的数量
                  for(inti= 0;i<ele.nodeCount();i++){
                        //取出下标为i的节点
                        Nodenode= ele.node(i);
                        //判断当前节点是否为标签
                        if(nodeinstanceofElement){
                              //把node强转为标签(Element)
                              treeWalk((Element)node);
                        }
                  }
            }
      }
    • public classTestDom4j {
            @Test
            publicvoidtest1()throwsException{
                  //创建一个xml解析对象
                  SAXReaderreader= new SAXReader();
                  //把xml文档加载到document对象中
                  Documentdocument= reader.read("src/Book.xml");
                  Elementroot= document.getRootElement();
      //          Element bookNode = root.element("书");
      //          System.out.println(bookNode.getName());
                  //得到当前节点所有的子节点
                  Listlist= root.elements();
                  //得到第二本书对象
                  ElementsecondBook= (Element)list.get(1);
                  //得到当前节点的文本内容
                  Stringname= secondBook.element("书名").getText();
                  System.out.println(name);
            }
    • 导入jar包 dom4j.jar

    • 创建解析器

    • 解析xml 获得document对象

    • SAXReader reader = new SAXReader()

    • Document document = reader.read(url)

    • JAXP sun公司提供的解析 支持dom和sax

    • JDOM

    • DOM4J dom for java民间方式,但是是事实方式,非常好,支持dom

    • 解析xml

    • XPATH 专门用于查询

以上是帶你深入了解XML的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn