SAX(Simple API for XML)也是一种解析 XML 文件的方法,它虽然不是官方标准,但它是 XML 的事实标准,大部分 XML 解析器都支持它。
SAX 与 DOM 不同的是,它不是一次性将 XML 加载到内存中,而是从 XML 文件的开始位置进行解析,根据定义好的事件处理器,来决定当前解析的部分是否有必要存储。下面例子说明了 SAX 解析 XML 的过程。
【例 1】SAX 解析 XML 文件。将《DOM 解析 XML》中例 1 的 XML 文件作为源文件,编写解析类 JAXBSAXDemo.java,代码如下:
package com.eshore; import org.xml.sax.Attributes; import org.xml.sax.SAXException; import org.xml.sax.XMLReader; import org.xml.sax.helpers.DefaultHandler; import org.xml.sax.helpers.XMLReaderFactory; public class JAXBSAXDemo extends DefaultHandler { private String preTag; //接收文档开始的通知 @Override public void startDocument() throws SAXException { preTag=null; } //接收元素开始的通知 @Override public void startElement(String uri, String localName,String qName,Attributes attributes)throws SAXException { if("user".equals(qName)) { System.out.println(qName+"节点的country属性值为:"+attributes.getValue("country")); } if("address".equals(qName)) { System.out.println(qName+"节点的state属性值为:"+attributes.getValue("state")); } preTag=qName; } //接收元素结束的通知 @Override public void endElement(String uri,String localName, String qName)throws SAXException { preTag=null; } //接收元素中数据的通知,在执行完startElement和endElement方法之后执行 public void characters(char ch[], int start, int length)throws SAXException { String value=new String(ch, start, length); if("name".equals(preTag)) { System.out.println("name节点的值为:"+value); } else if("english_name".equals(preTag)) { System.out.println("english_name节点的值为:"+value); } else if("age".equals(preTag)) { System.out.println("age节点的值为:"+value); } else if("sex".equals(preTag)) { System.out.println("sex节点的值为:"+value); } else if("description".equals(preTag)) { System.out.println("description节点的值为:"+value); } if("city".equals(preTag)) { System.out.println("city节点的值为:"+value); } else if("area".equals(preTag)) { System.out.println("area节点的值为:"+value); } } public static void main(String[] args) throws Exception { //由XMLReaderFactory类 创建XMLReader实例 XMLReader xmlReader=XMLReaderFactory.createXMLReader(); //创建一事件监听类 JAXBSAXDemo handler=new JAXBSAXDemo(); //XMLReader解析类设定事件处理类 xmlReader.setContentHandler(handler); //XMLReader解析类解析XML文件 xmlReader.parse("E://users.xml"); } }
上述代码中介绍了用 SAX 解析 XML 文件的步骤。通过上述代码可以看出,使用 SAX 解析 XML 时,需要以下几个步骤:
- 用 XMLReaderFactory 类创建 XMLReader 实例:
XMLReader xml Reader=XMLReaderFactory. createXMLReader();
- 创建一个事件监听类:
JAXBSAXDemo handler=new JAXBSAXDemo();
- 为解析类设定事件处理类:
xmlReader.setContentHandler(handler);
- 解析XML文件:
xmlReader. parse ("E://users.xml");
提示:上述实例中应用的是 XMLReader 而不是 SAXParser,是因为在 SAX2 中实现解析的接口名称重命名为 XMLReader。在使用 SAX 解析 XML 资源文件时,默认使用 SAXParser 实现类,它继承自 AbstractSAXParser。同理,工厂类也是使用 XMLReaderFactory 而不只 ISASParserFactory 来创建解析类。
原创文章,作者:奋斗,如若转载,请注明出处:https://blog.ytso.com/22219.html