XML学习日记
学习日记01XMl语法: 1.文档声明: 在编写XML文档时,需要先使用XML文档声明,声明XML文档的类型 最简单的文档声明语法:<?xml version=”1.0” ?> 用encoding属性说明文档的字符编码 <?xml version=”1.0”encoding=”UTF-8” ?> 用standalone属性说明文档是否独立: <?xmlversion=”1.0” encoding=”UTF-8” standalone=”yes” ?> 2.元素:XML中出现的标签,一个标签分为开始标签和结束标签,一个标签有如下几种书写形式: 一个标签中也可以嵌套若干子标签。但所有标签必须合理的嵌套,绝对不允许交叉嵌套,例如: <a>welcome to<b>www.it315.org</a></b> 格式良好的XML文档必须有且仅有一个根标签,其它标签都是这个根标签的子孙标签 对于XML标签中出现的所有空格和换行,XML解析程序都会当作标签内容进行处理。例如:下面两段内容的意义是不一样的 <网址>www.itcast.cn</网址> <网址> www.itcast.cn </网址> 由于在XML中,空格和换行都作为原始内容被处理,所以,在编写XML文件时,使用换行和缩进等方式来让原文件中的内容清晰可读的“良好”书写习惯可能要被迫改变。 l 一个XML元素可以包含字母、数字以及其它一些可见字符,但必须遵守下面的一些规范: l 区分大小写,例如,<P>和<p>是两个不同的标记。 l 不能以数字或"_" (下划线)开头。 l 不能以xml(或XML、或Xml 等)开头。 l 不能包含空格。 l 名称中间不能包含冒号(:)。 3.属性 一个标签可以有多个属性,每个属性都有它自己的名称和取值,例如: <input name=“text”> 属性值一定要用双引号(")或单引号(')引起来 定义属性必须遵循与标签相同的命名规范 多学一招:在XML技术中,标签属性所代表的信息,也可以被改成用子元素的形式来描述,例如: <input> <name>text</name> </input> 4.注释 Xml文件中的注释采用:“<!--注释-->” 格式。 注意: XML声明之前不能有注释 注释不能嵌套,例如: <!--大段注释 …… <!--局部注释--> …… --> 5.CDATA区,特殊字符 在编写XML文件时,有些内容可能不想让解析引擎解析执行,而是当作原始内容处理 遇到此种情况,可以把这些内容放在CDATA区里,对于CDATA区域内的内容,XML解析程序不会处理,而是直接原封不动的输出。 语法:<![CDATA[ 内容 ]]> <![CDATA[ <itcast> <br/> </itcast> ]]> 6.处理指令(processing instruction) 简称PI (processing instruction)。处理指令用来指挥解析引擎如何解析XML文档内容。 例如,在XML文档中可以使用xml-stylesheet指令,通知XML解析引擎,应用css文件显示xml文档内容。 <?xml-stylesheettype="text/css" href="1.css"?> 处理指令必须以“<?”作为开头,以“?>”作为结尾,XML声明语句就是最常见的一种处理指令。 XML约束:在XML技术里,可以编写一个文档来约束一个XML文档的书写规范,这称之为XML约束 l 常用的约束技术 XML DTD (DocumentType Definition),全称为文档类型定义 XML Schema 引用DTD约束: l XML文件使用 DOCTYPE 声明语句来指明它所遵循的DTD文件,DOCTYPE声明语句有两种形式: 当引用的文件在本地时,采用如下方式: <!DOCTYPE 文档根结点 SYSTEM "DTD文件的URL"> 例如: <!DOCTYPE 书架 SYSTEM “book.dtd”>。在xml文件中手写一下。 当引用的文件是一个公共的文件时,采用如下方式: <!DOCTYPE 文档根结点 PUBLIC "DTD名称" "DTD文件的URL"> 例如:<!DOCTYPE web-app PUBLIC "-//SunMicrosystems,Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd"> DTD约束语法细节: l 元素定义 在DTD文档中使用ELEMENT声明一个XML元素,语法格式如下所示: <!ELEMENT 元素名称 元素类型> 元素类型可以是元素内容、或类型 ?如为元素内容:则需要使用()括起来,如 <!ELEMENT 书架(书名,作者,售价)> <!ELEMENT 书名(#PCDATA)> ? 如为元素类型,则直接书写,DTD规范定义了如下几种类型: ?EMPTY:用于定义空元素,例如<br/> <hr/> ?ANY:表示元素内容为任意类型。 元素内容中可以使用如下方式,描述内容的组成关系 ? 用逗号分隔,表示内容的出现顺序必须与声明时一致。<!ELEMENT MYFILE(TITLE,AUTHOR,EMAIL)> ? 用|分隔,表示任选其一,即多个只能出现一个 <!ELEMENT MYFILE (TITLE|AUTHOR|EMAIL)> 在元素内容中也可以使用+、*、?等符号表示元素出现的次数: +: 一次或多次 (书+) ?:0次或一次 (书?) *: 0次或多次 (书*) 也可使用圆括号( )批量设置,例 <!ELEMENT MYFILE ((TITLE*,AUTHOR?,EMAIL)* | COMMENT)> l 属性定义 xml文档中的标签属性需通过ATTLIST为其设置属性 语法格式: <!ATTLIST元素名 属性名1 属性值类型 设置说明 属性名2 属性值类型 设置说明 …… > 属性声明举例: <!ATTLIST 商品 类别 CDATA #REQUIRED 颜色 CDATA #IMPLIED > 对应XML文件: <商品类别="服装" 颜色="黄色">…</商品> <商品类别="服装">…</商品> 设置说明: ? #REQUIRED:必须设置该属性 ? #IMPLIED:可以设置也可以不设置 ? #FIXED:说明该属性的取值固定为一个值,在 XML 文件中不能为该属性设置其它值。但需要为该属性提供这个值 直接使用默认值:在 XML 中可以设置该值也可以不设置该属性值。若没设置则使用默认值 举例: <!ATTLIST 页面作者 姓名 CDATA #IMPLIED 年龄 CDATA #IMPLIED 联系信息 CDATA #REQUIRED 网站职务 CDATA #FIXED "页面作者" 个人爱好 CDATA "上网" > 常用属性值类型: l CDATA:表示属性值为普通文本字符串。 l ENUMERATED l ID l ENTITY(实体) 属性值类型àENUMERATED l 属性的类型可以是一组取值的列表,在 XML 文件中设置的属性值只能是这个列表中的某个值(枚举) <?xml version ="1.0" encoding="GB2312" standalone="yes"?> <!DOCTYPE 购物篮 [ <!ELEMENT肉 EMPTY> <!ATTLIST肉 品种 ( 鸡肉 | 牛肉 | 猪肉 | 鱼肉 ) "鸡肉"> ]> <购物篮> <肉 品种="鱼肉"/> <肉 品种="牛肉"/> <肉/> </购物篮> 属性值类型à ID 表示属性的设置值为一个唯一值。 ID 属性的值只能由字母,下划线开始,不能出现空白字符 l 实体定义: 实体用于为一段内容创建一个别名,以后在XML文档中就可以使用别名引用这段内容了。 在DTD定义中,一条<!ENTITY …>语句用于定义一个实体。 实体可分为两种类型:引用实体和参数实体。 实体定义à引用实体 : l 引用实体主要在 XML 文档中被应用 l 语法格式: ?<!ENTITY实体名称 “实体内容” >:直接转变成实体内容 l 引用方式: &实体名称; l 举例: <!ENTITYcopyright “I am a programmer"> …… ©right; 实体定义à参数实体: 参数实体被 DTD 文件自身使用 语法格式: <!ENTITY % 实体名称 "实体内容" > 引用方式: %实体名称; 举例1: <!ENTITY % TAG_NAMES "姓名 | EMAIL | 电话 | 地址">
<!ELEMENT 个人信息 (%TAG_NAMES; | 生日)> <!ELEMENT 客户信息 (%TAG_NAMES; | 公司名)> 举例2: <!ENTITY % common.attributes " id ID #IMPLIED account CDATA #REQUIRED" > ... <!ATTLIST purchaSEOrder %common.attributes;> <!ATTLIST item %common.attributes;> XML编程(CRUD)XML解析技术概述: lXML解析方式分为两种:dom和sax ldom:(Document Object Model,即文档对象模型) 是W3C 组织推荐的处理XML 的一种方式。 lsax: (Simple API for XML) 不是官方标准,但它是 XML 社区事实上的标准,几乎所有的 XML 解析器都支持它。 lXML解析器 ? Crimson(sun)、Xerces(IBM) 、Aelfred2(dom4j) lXML解析开发包 ? Jaxp(sun)(最差)、Jdom(jdom)(中等,基本不用)、dom4j(dom4j)(最优) 使用JAXP进行DOM解析: ljavax.xml.parsers包中的DocumentBuilderFactory用于创建DOM模式的解析器对象 , DocumentBuilderFactory是一个抽象工厂类,它不能直接实例化,但该类提供了一个newInstance方法,这个方法会根据本地平台默认安装的解析器,自动创建一个工厂的对象并返回。 SAX解析: SAX解析XML文档,涉及两个部分:解析器和事件处理器: 解析器可以使用JAXP的API创建,创建出SAX解析器后,就可以指定解析器去解析某个XML文档。 解析器采用SAX方式在解析某个XML文档时,它只要解析到XML文档的一个组成部分,都会去调用事件处理器的一个方法,解析器在调用事件处理器的方法时,会把当前解析到的XML文件内容作为方法的参数传递给事件处理器。 事件处理器有程序员编写,程序员通过事件处理器中方法的参数,就可以很轻松地得到SAX解析器解析到的数据,从而可以决定如何对数据进行处理。 SAX方式解析XML文档: l使用SAXParserFactory创建SAX解析工厂 SAXParserFactory spf = SAXParserFactory.newInstance(); l通过SAX解析工厂得到解析器对象 SAXParser sp = spf.newSAXParser(); l通过解析器对象得到一个XML的读取器 XMLReader xmlReader = sp.getXMLReader(); l设置读取器的事件处理器 xmlReader.setContentHandler(new BookParserHandler()); l解析xml文件 xmlReader.parse("book.xml"); DOM4J解析XML文档: DOM4j中,获得Document对象的方式有三种: 1.读取XML文件,获得document对象 SAXReader reader = new SAXReader(); 2.解析XML形式的文本,得到document对象. String text = "<members></members>"; 3.主动创建document对象. Document document = DocumentHelper.createDocument(); Elementroot = document.addElement("members"); 1.获取文档的根节点. Element root =document.getRootElement(); 2.取得某个节点的子节点. Elementelement=node.element(“书名"); 3.取得节点的文字 Stringtext=node.getText(); 4.取得某节点下所有名为“member”的子节点,并进行遍历. 5.对某节点下的所有子节点进行遍历. 6.在某节点下添加子节点. 7. 设置节点文字. 8. 删除某节点. parentElm.remove(childElm); 9. 添加一个CDATA节点.
节点对象属性: l1.取得某节点下的某属性 Attributeattribute=root.attribute("size"); l2.取得属性的文字 l3.删除某属性 l4.遍历某节点的所有属性 l5.设置某节点的属性和文字. l6.设置属性的文字 将文档写入XML文件: 1.文档中全为英文,不设置编码,直接写入的形式. 2.文档中含有中文,设置编码格式写入的形式. format.setEncoding("GBK"); XML Schema: XML Schema 也是一种用于定义和描述 XML 文档结构与内容的模式语言,其出现是为了克服 DTD 的局限性 XML Schema VS DTD: XML Schema符合XML语法结构。 DOM、SAX等XML API很容易解析出XML Schema文档中的内容。 XML Schema对名称空间支持得非常好。 XML Schema比XML DTD支持更多的数据类型,并支持用户自定义新的数据类型。 XML Schema定义约束的能力非常强大,可以对XML实例文档作出细致的语义限制。 XML Schema不能像DTD一样定义实体,比DTD更复杂,但Xml Schema现在已是w3c组织的标准,它正逐步取代DTD。 Schema约束快速入门: XML Schema 文件自身就是一个XML文件,但它的扩展名通常为.xsd。 一个XML Schema文档通常称之为模式文档(约束文档),遵循这个文档书写的xml文件称之为实例文档。 和XML文件一样,一个XML Schema文档也必须有一个根结点,但这个根结点的名称为Schema。 编写了一个XML Schema约束文档后,通常需要把这个文件中声明的元素绑定到一个URI地址上,在XML Schema技术中有一个专业术语来描述这个过程,即把XML Schema文档声明的元素绑定到一个名称空间上,以后XML文件就可以通过这个URI(即名称空间)来告诉解析引擎,xml文档中编写的元素来自哪里,被谁约束。 使用名称空间引入Schema: 为了在一个XML文档中声明它所遵循的Schema文件的具体位置,通常需要在Xml文档中的根结点中使用schemaLocation属性来指定,例如: <itcast:书架xmlns:itcast="http://www.itcast.cn" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation=“http://www.itcast.cn book.xsd"> schemaLocation此属性有两个值。第一个值是需要使用的命名空间。第二个值是供命名空间使用的 XML schema的位置,两者之间用空格分隔。 注意,在使用schemaLocation属性时,也需要指定该属性来自哪里。 使用默认名称空间: 基本格式: xmlns="URI" 举例: <书架xmlns="http://www.it315.org/xmlbook/schema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation=“http://www.itcast.cn book.xsd"> <书> <书名>JavaScript网页开发</书名> <作者>张孝祥</作者> <售价>28.00元</售价> </书> <书架> (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |