schema约束
1.dtd语法:<!ELEMENT元素名称 约束>
schema符合xml的语法,xml语句
一个xml中可以有多个schema,多个schema使用名称空间区分(类似于java包名)
dtd里面有PCDATA类型,但是在schema可以直接定义一个整数类型
schema语法更加复杂,schema目前不能代替dtd
2.schema的快速入门
创建一个schema文件 后缀名是.xsd
根节点<schema>
在schema文件里面
属性: xmlns="http://www.w3.org/2001/XMLSchema"(表示当前xml文件是一个约束文件)
- targetNamespace="http://www.itcast.cn/20151111"(使用schema约束文件,直接通过这个地址引入约束文件)
-
elementFormDefault="qualified"
步骤:(1)看xml中有多少个元素<element>
(2)看简单元素和复杂元素
如果复杂元素<complexType>
<sequence> 子元素
</sequence> <complexType>
(3)在被约束文件里面引入约束文件
<sequence>:表示元素出现的顺序
<all>:元素只能出现一次
<choice>:元素只能出现其中的一个
maxOccurs="unbounded":表示元素的出现的次数
<any></any>:表示任意元素
可以约束属性
写在复杂元素里面
写在</compelxeType>之前
--
<attribute name="id1 type="int" use"required"></attribute> - name:属性名称
- type: 属性类型 int string
- use: 属性是否必须出现 required
3.sax解析的原理
解析xml有两种技术 dom 和sax
根据xml的层级结构在内存中分配一个树形结构
把xml中标签,属性,文本封装成对象
sax方式:事件驱动,编读边解析
在javax.xml.parsers包里面
SAXParser
此类的实例可以从SAXParserFactory.newSAXParse()方法获得
-parse(File f,DefaultHandler dh)
两个参数 第一个参数:xml的路径 第二个 时间处理器
分析一下sax执行过程
当解析道开始标签的时候,自动执行startElement方法
当解析到文本时候,自动执行characters方法
当解析到结束标签的时候,自动执行endElement方法
4.使用jaxp的sax方式解析xml
sax方式不能实行增删改操作,只能做查询操作
打印出整个文档
执行parse方法,第一个参数xml路径,第二个参数是时间处理器
创建一个类,继承时间处理器的类,
重写里面的三个方法
获取到所有的name元素的值
定义一个成员变量flag=false
判断开始方法是否是name元素,如果是name元素,吧flag值设置成true
如果flag值是true,在characters方法里面打印内容
当执行到结束方法时候,把flag值设置成false
使用dom4解析xml
dom4j是一个组织,针对xml解析,提供解析器dom4j
dom4j不是javase的一部分,想要使用第一步需要怎么做:
- 创建一个文件夹lib
- 复制jar包到lib下面
右键点击jar包,build path--add to buildpath - 看到jar包,变成奶瓶的样子,表示导入成功
得到document
SAXReader reader=new SAXReader();
Document document= reader.read(rul);
document的父接口是Node
document里面的方法 getRootElement():获取根结点 返回的是Element
Element也是一个接口,父接口是Node
Element和Node里面方法
getparent():获取父节点
addElement:添加标签
6.使用dom4j查询xml
查询所有name元素里面的值
/*
1.创建解析器
2.得到document
3.得到根节点 getrootElement()
4.得到所有的p1标签 - element(qname)
表示获取标签下面的第一个子标签 - elements(qname)
表示获取标签下面的所有子标签 - elements()
5.得到name
6.得到name里面的值
/
7.使用dom4j实现添加操作
/1.创建解析器
2.得到document
3.得到根节点 getrootElement()
4.得到所有的p1
5.在p1下面添加元素
在p1上直接使用addElement方法
6.在添加完成之后的元素下面添加文本
7.回写xml
/
8.在特定位置添加元素
/1.创建解析器
2.得到document
3.得到根节点 getrootElement()
4.得到所有的p1
5.获取p1下面的所有的元素
6.回写xml
*/
可以对得到document的操作和会写xml的操作,封装成方法
也可以把传递的文件的路径,封装成一个常量
好处:可以提高开发速度,可以提高代码可维护性
9.使用dom4j实现修改节点的操作
1.得到document
2.得到根节点 getrootElement()
3.得到所有的p1下面的age
element("")方法
4.修改值是30
5.回写xml
10.使用dom4j实现删除节点的操作
1.得到document
2.得到根节点 getrootElement()
3.得到第一个p1标签
4.得到第一个p1下面的school元素
5.删除(使用p1删除school)
6.回写xml
11.使用dom4j获取属性的操作
1.得到document
2.得到根节点 getrootElement()
3.得到第一个p1元素
4.得到p1里面的属性值
12.使用dom4j支持xpath的操作
可以直接获取到某个元素