分析案例javaxml课程.pptx

  1. 1、本文档共35页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多

XML解析健哥

SAX解析SimpleApiforXML。SAX在解析文档时使用的是边读取边解析的方式,而不是一次性的将文档全部装入内存中。所以它的读取速度很快,占用很少的内存。仅向前,不能任意的读取一个节点。也不能修改XML文件。

SAX读取一个XML文档的过程:

SAX解析器:SAXParserFactory定义工厂API,使应用程序能够配置和获取基于SAX的解析器以解析XML文档。SAXParser–是SAX解析器。

定义包装XMLReader实现类的API。此类的实例可以从SAXParserFactory.newSAXParser()方法获得。XMLReader-用于读取XML数据。通过SAXParser.getXMLReader()获得。parse(StringfileName)用于读取一个XML文档。

示例:

SAX读取XML文档:SAXParserFactorysf=SAXParserFactory.newInstance();SAXParsersax=sf.newSAXParser();//使用parse方法解析一个XML文档,使用内部类sax.parse(newFile(./xml2/a.xml),newDefaultHandler(){ …//处理具体代码});

StAX:TheStreamingAPIforXML基于流的XML编程接口StAX即可读文档也可以写文档。而SAX只可以读取文档。

StAX的API编程接口StAX编程接口都位于javax.xml.stream包中。StAX提供了两种方式的编程接口,它们是:IteratorAPI它的特点是:方便易用、实现简单。主要类是:XMLEventReader和XMLEventWriter。CrusorAPI它的特点是:运行速度快,底层编程。主要类是:XMLStreamReader和XMLStreamWriter。

IteratorAPI编程接口XMLEvent提供一系列的属性方法,判断文件是开始、结束。StartDocument文档的开始StartElement、EndElement(元素的开始与结束)、Characters(字符串节点元素)EntityReference实体引用Comment注释、EndDocument文档结束,DTD约束Attribute属性,Namespace命名空间2、XMLEventReader提供遍历XML文档的能力。它的源代码如下:publicinterfaceXMLEventReaderextendsIterator{可见,它就是一个遍历器。XMLEventWriterXMLEventWriter提供向写XML的功能。

StAX的工厂类XMLInputFactory、XMLOutputFactory、XMLEventFactory是StAX的工厂类,通过这些类可以获取reader、writer和event的实例。

XMLEventReader遍历文档:

CursorAPI编程接口:CursorAPI提供两个实现实现对XML的读写,XMLStreamReader负责仅向前的读取数据。XMLStreamWriter可快速且简单的写出一个XML文档。

总结:SAX确实在读取文档上是一边读取一边解析,但它只能读取一次,更不能进行CRUD操作。-基于事件。在JDK1.6中又添加了SAX的近亲StAX-基于Stream流。

Dom4j:Dom4j是一个开源、灵活的XMLAPI。目前很多开源框架如struts,hibernate都使用dom4j做为解析其xml的工具。支持文档的读写功能和Xpath快速查询操作。

准备DOM4j:包:dom4j.x.jar包结构:org.dom4j类org.dom4j.io.SAXReader–xml文档解析器org.dom4j.Document、Element–文档对像Element的一些方法Element.element(“name”)–此元素下的第一个name元素。Element.elementIterator(“name”)–此元素下的所有name元素。返回IteratorElement.getText()–返回元素包含的文本。Element.getAttribute(“name”)–返回名称为name的属性。Element.addElement(“name”);-添加一个name元素,同时返回name元素本身。org.dom4j.io.XMLWriter–将Document写出的对像。

准备XML数据:?xmlversion=1.0encoding=UTF-8?use

文档评论(0)

159****9610 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:6044052142000020

1亿VIP精品文档

相关文档