`

stax方法解析XML

xml 
阅读更多
一SAX解析
   SAX(simple API for XML)是一种XML解析的替代方法。相比于DOM,SAX是一种速度更快,更有效的方法。它逐行扫描文档,一边扫描一边解析。而且相比于DOM,SAX可以在解析文档的任意时刻停止解析,但任何事物都有其相反的一面,对于SAX来说就是操作复杂。
 
(1)解析初步
  JAVA 解析 XML 通常有两种方式:DOM 和SAX。DOM(文档对象模型)是W3C标准,提供了标准的解析方式,但其解析效率一直不尽如人意,这是因为DOM解析XML文档时,把所有内容一次性的装载入内存,并构建一个驻留在内存中的树状结构(节点数)。如果需要解析的XML文档过大,或者我们只对该文档中的一部分感兴趣,这样就会引起性能问题。


(2)SAX的工作原理
     SAX,它既是一个接口,也是一个软件包.但作为接口,SAX是事件驱动型XML解析的一个标准接口不会改变 SAX的工作原理简单地说就是对文档进行顺序扫描,当扫描到文档(document)开始与结束、元素(element)开始与结束、文档(document)结束等地方时通知事件处理函数,由事件处理函数做相应动作,然后继续同样的扫描,直至文档结束。
  大多数SAX都会产生以下类型的事件:
  1.在文档的开始和结束时触发文档处理事件。
  2.在文档内每一XML元素接受解析的前后触发元素事件。
  3.任何元数据通常由单独的事件处理
  4.在处理文档的DTD或Schema时产生DTD或Schema事件。
  5.产生错误事件用来通知主机应用程序解析错误。

(3)SAX解析文档过程举例
  对于一个XML文档举例来说 <doc>
  <para>Hello,World!</para>
  </doc>
  其解析的过程为:
  1.start document
  2.start element:doc......
  3.start element:para.....
  4.characters:Hello,World!
  5.end element:para......
  6.end element;doc......
  7.end document
  对于解析过程中的每一步都会有事件发生,都会触发相应接口中的事件处理程序。
  编写程序的步骤为:
  (1).创建事件处理程序(也就是编写ContentHandler的实现类,一般继承自DefaultHandler类,采用adapter模式)
  (2).创建SAX解析器
  (3).将事件处理程序分配到解析器
  (4).对文档进行解析,将每个事件发送给事件处理程序

(4)SAX 模型
  过程:
  1.首先SAXParserFactory来创建一个SAXParserFactory实例
  SAXParserFactory factory = SAXParserFactory.newInstance();
  2.根据SAXParserFactory实例来创建SAXParser
  3.SAXParser产生SAXReader
  XMLReader reader = factory.newSAXParser().getXMLReader();
  4.XMLReader 加载XML,然后解析XML,在解析的过程中触发相对于接口中的事件处理程序

(5)SAX接口介绍
  ContentHandler接口 (主要用到的接口)
  ContentHandler是Java类包中一个特殊的SAX接口,位于org.xml.sax包中。该接口封装了一些对事件处理的方法,当XML解析器开始解析XML输入文档时,它会遇到某些特殊的事件,比如文档的开头和结束、元素开头和结束、以及元素中的字符数据等事件。当遇到这些事件时,XML解析器会调用ContentHandler接口中相应的方法来响应该事件。
  ContentHandler接口的方法有以下几种:
  void startDocument()
  void endDocument()
  void startElement(String uri, String localName, String qName, Attributes atts)
  void endElement(String uri, String localName, String qName)
  void characters(char[ ] ch, int start, int length)

DTDHandler接口
  DTDHandler用于接收基本的DTD相关事件的通知。该接口位于org.xml.sax包中。此接口仅包括DTD事件的注释和未解析的实体声明部分。SAX解析器可按任何顺序报告这些事件,而不管声明注释和未解析实体时所采用的顺序;但是,必须在文档处理程序的startDocument()事件之后,在第一个startElement()事件之前报告所有的DTD事件。
  DTDHandler接口包括以下两个方法
  void startDocumevoid notationDecl(String name, String publicId, String systemId) nt()
  void unparsedEntityDecl(String name, String publicId, String systemId, String notationName)
  EntityResolver接口
  EntityResolver接口是用于解析实体的基本接口,该接口位于org.xml.sax包中。
  该接口只有一个方法,如下:
  public InputSource resolveEntity(String publicId, String systemId)
  解析器将在打开任何外部实体前调用此方法。此类实体包括在DTD内引用的外部DTD子集和外部参数实体和在文档元素内引用的外部通用实体等。如果SAX应用程序需要实现自定义处理外部实体,则必须实现此接口。ErrorHandler接口
  ErrorHandler接口是SAX错误处理程序的基本接口。如果SAX应用程序需要实现自定义的错误处理,则它必须实现此接口,然后解析器将通过此接口报告所有的错误和警告。
  该接口的方法如下:
  void error(SAXParseException exception)
  void fatalError(SAXParseException exception)
  void warning(SAXParseException exception)
分享到:
评论

相关推荐

    用Stax组装及解析XML

    使用StAX解析XML文档则需要借助`XMLInputFactory`和`XMLStreamReader`类完成。下面是一个简单的例子: ```java XMLInputFactory factory = XMLInputFactory.newInstance(); XMLStreamReader reader = factory....

    stax+jaxb进行xml解析

    在Java中,有多种方法可以解析XML,其中StAX(Streaming API for XML)和JAXB(Java Architecture for XML Binding)是两种常用的技术。本篇文章将详细探讨如何结合StAX和JAXB进行高效的XML解析。 StAX是一种事件...

    kettle解析xml多层分组嵌套数据,StAX方法,完整解析案例(包含xml文件以及ktr文件)

    kettle 解析xml数据,xml多层分组嵌套,xml stax方法,完整解析案例使用(包含xml文件以及ktr文件)。ETL大数据迁移,数据清洗。XML Input Stream (StAX) 方法

    kettle 解析xml xml文档,配合kettle 解析xml stax方法,完整解析案例使用

    与上一个版本一起使用可以可以起到提高效率的目的。本人解析xml的真实文档

    stax 解析xml demo project

    STAX解析XML的过程是通过事件驱动的,即在解析XML时,解析器会触发一系列事件,如遇到元素开始、元素结束、文本节点等,开发者注册监听这些事件,然后在事件触发时进行相应的处理。相比于DOM(Document Object ...

    Stax组装及解析XML的例子

    Axis2在性能上的提升也得益于采用StAX解析XML。 总之,StAX提供了一种高效、低内存开销的方式来处理XML,尤其适用于处理大型XML文档和需要高性能的应用场景。通过组装和解析XML,开发人员可以灵活地在应用程序之间...

    java xml 4 种 解析xml 方法 sax jdom dom stAX

    下面将详细介绍这四种解析XML的方法。 1. SAX(Simple API for XML) SAX是一种事件驱动的解析器,它不会一次性加载整个XML文档到内存中,而是逐行读取,当遇到文档中的元素、属性等时,会触发相应的事件处理器方法...

    kettle转换xml(XML Input Stream (StAX))

    这个实例展示了如何使用StAX解析XML并将其数据写入目标系统。 总结来说,Kettle的XML Input Stream (StAX) 提供了一种高效、内存友好的方式来处理XML数据。通过合理配置,我们可以轻松地从XML文件中提取数据,然后...

    java 解析xml 多级

    总结来说,Java提供了多种解析XML的方法,包括DOM、SAX和JAXB等。对于处理多级嵌套的XML,DOM和JAXB在操作上更为便捷,而SAX则适用于处理大规模文件。在具体选择时,应根据项目需求和资源限制进行权衡。

    java解析xml的四种经典方法

    Java解析XML的四种经典方法是XML处理中常用的技术,它们分别是DOM、SAX、StAX和JDOM。每种方法都有其独特的特性和适用场景,下面将详细介绍这四种方法。 1. DOM(Document Object Model)解析: DOM是W3C制定的一种...

    java使用stax技术操作XML文档.doc

    StAX的核心理念是将XML视为一个事件流,允许应用程序主动拉取并处理这些事件,而不是被动等待解析器推送事件,就像SAX所做的那样。StAX提供了两个级别的API:基于指针的API和基于迭代器的API。 基于指针的API通过...

    使用StAX进行高效的XML处理中文版

    ### 使用StAX进行高效的XML处理 #### 概述 StAX(Streaming API for XML)是一种新的XML解析方式,它提供...无论是对于需要处理大量数据的应用程序还是需要高效解析XML的应用场景,StAX都是一种值得考虑的技术选择。

    详解Java解析XML的四种方法

    本文将深入探讨Java解析XML的四种主要方法。 1. DOM(Document Object Model)解析: DOM解析器将整个XML文档加载到内存中,创建一个树形结构,允许开发者通过节点遍历和操作XML。例如,Java的`javax.xml.parsers....

    使用JDOM解析XML文件

    本篇文章将深入探讨如何使用JDOM解析XML文件。 首先,我们需要理解JDOM的基本结构。JDOM通过Document对象表示整个XML文档,Element代表XML元素,Attribute表示元素属性,Text表示元素内的文本内容。这些类构成了...

    JAVA调用webservice并解析xml

    在IT行业中,调用Web服务并解析XML是常见的任务,特别是在Java开发中。Web服务,尤其是基于SOAP(Simple Object Access Protocol)的,提供了一种标准的跨平台、跨语言的数据交换方式。本教程将深入讲解如何在Java...

    解析XML文件的四种方式整合

    本文将详细讲解四种解析XML文件的方法,旨在帮助初学者更好地理解和掌握XML处理技术。 1. DOM解析器(Document Object Model) DOM解析器将整个XML文档加载到内存中,构建一个树形结构,称为DOM树。这个方法的优点...

    Java 解析 xml 3种方法

    DOM4J支持DOM、SAX和StAX解析器,并且包含了XPath表达式的支持,使得查找XML元素更为便捷。DOM4J的使用流程类似JDOM,但其API设计更加灵活,能更方便地处理XML文档。 以下是这三种方法的比较: - **SAX**:适合处理...

    使用java解析XML文件,解析完之后将解析结果导入mysql数据库中

    可以考虑使用SAX或者StAX解析器,它们是事件驱动的,只在需要时处理XML数据,减少内存占用。 5. **安全性**: - 防止SQL注入:使用预编译的`PreparedStatement`可以避免SQL注入攻击,确保参数安全。 - 输入验证:...

    java解析XML文件

    Java解析XML文件是Java开发中常见的一项任务,XML(eXtensible Markup Language)作为一种可扩展标记语言,常用于数据交换、配置存储等场景。在Java中,有多种方式可以解析XML文件,主要包括DOM(Document Object ...

Global site tag (gtag.js) - Google Analytics