SAX解析XML

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

(0)
上一篇 2021年7月20日
下一篇 2021年7月20日

相关推荐

发表回复

登录后才能评论