schema约束

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)在被约束文件里面引入约束文件


    图片.png

    <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的操作
可以直接获取到某个元素

推荐阅读更多精彩内容

  • day5 一、表单提交方式 1.使用submit提交 2.使用button提交表单 3.使用超链接提交 4.onc...
    mwj610阅读 122评论 0 0
  • 1. XML总结 1.1. XML简介 XML : 可扩展的标记语言。(和HTML非常类似的) 可扩展的。 自定义...
    Ethan_Walker阅读 1,710评论 0 11
  • Schema 另一种约束xml文档的语法那就是Schema,用于替代老式的DTD约束。 什么是XML Schema...
    免费的午餐阅读 210评论 0 0
  • Schema与DTD XML Schema符合XML语法结构。 DOM、SAX等XML API很容易解析出XML ...
    扒块腹肌阅读 1,293评论 0 4
  • Schema简介 XML Schema也被称为XML Schema定义(XML Schema Definition...
    tobe_superman阅读 3,449评论 0 7