java用DefaultHandler解析XML格式数据

本文介绍了一个使用Java SAX解析XML配置文件的具体实现案例。通过自定义DefaultHandler子类,文章详细展示了如何利用栈来跟踪XML元素,并提取关键路径及连接信息。

XML格式数据,即可扩展标记语言(标准通用标记语言的子集)是一种简单的数据存储语言。

//DefaultHandler解析XML格式数据
class ParserXml extends DefaultHandler{

    /*
     * 使用stack数据结构,它是后进先出的特点
     */
    private Stack<String> stack = new Stack<String>();
    //返回的保存着配置文件路径的字符串数组

    ArrayList<String> list=new ArrayList<String>();

    //定义变量用来保存数据
    private String path1;
    private String path2;
    private String addr;
    private String port;
    private String URL;
    //开始解析
    public void startElement(String uri, String localName, String qName,Attributes attributes) throws SAXException {
        //qName:表示元素的名字,标签的名字。
        stack.push(qName); //将元素名字压到栈顶
    }

    //解析
    public void characters(char[] ch, int start, int length)
            throws SAXException {
        //peek()把栈中的值拿出来,当不弹出来,只取出值而已
        //pop()把栈中的值弹出来
        String tag = stack.peek(); 

        //在输出元素内容之前,我们必须知道当前元素是哪一个元素,所以我们要进行判断
        if("path1".equals(tag)){
            //提取元素内容
            path1 = new String(ch, start, length);
        }
        else if("path2".equals(tag)){
            path2 = new String(ch, start, length);
        }else if("addr".equals(tag))
        {
            addr=new String(ch, start, length);
        }
        else if("port".equals(tag)){
            port=new String(ch, start, length);
        }else if("URL".equals(tag))
        {
            URL=new String(ch, start, length);
        }
    }
    //结束解析
    public void endElement(String uri, String localName, String qName)
            throws SAXException {
        //遇到元素结尾,表示该元素已经解析完毕,需要从栈中弹出
        stack.pop();
        //monitorpath下的元素
        if("monitorpath".equals(qName))
        {
            list.add(path1);
            list.add(path2);
        }
        //ftp下的元素
        else if("ftp".equals(qName))
        {
            list.add(addr);
            list.add(port);
        }
        //DataBase下的元素
        else if("DataBase".equals(qName))
        {
            list.add(URL);
        }
    }
    public ArrayList<String> Xmlreturn(String path,ParserXml xh)
    {
        //创建解析工厂
        SAXParserFactory factory = SAXParserFactory.newInstance();
        //得到SAX的解析器
        try {
            SAXParser parser = factory.newSAXParser();
            parser.parse(new File(path), xh);
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        //返回数据集合
        return list;
    }

public static void main(String[] args)
{
    ParserXml parserXml=new ParserXml();
    //传入xml数据的路径和解析工厂   
    ArrayList<String> arrayList=parserXml.Xmlreturn("path.xml",parserXml);
    for(String s:arrayList)
    {
        System.out.println(s);
    }
}
}

上面是解析xml的代码,将如下xml格式数据和工程放在一起即可。路径也可以自己定义输入。

<?xml version="1.0" encoding="UTF-8"?>
<user>
    <!--目录监控的信息-->
    <monitorpath>
        <path1>E:\\Listentest</path1>
        <path2>null</path2>
    </monitorpath>
    <!--FTP服务器的链接信息-->
    <ftp>
        <addr>127.0.0.1</addr>
        <port>21</port>
    </ftp>
    <DataBase>
        <URL>jdbc:mysql://127.0.0.1:3306/dataaudit</URL>
    </DataBase>
</user>
通常可能是想问Java解析XML格式数据的方法。目前解析XML主流的方法有四种,即DOM(Document Object Model)、SAX(Simple API for XML)、JDOM(Java - based Document Object Model)和DOM4J(Document Object Model for Java)。其中前两种属于基础方法,是官方提供的平台无关的解析方式;后两种属于扩展方法,它们是在基础的方法上扩展出来的,只适用于Java平台[^2]。 SAX是一种XML解析的替代方法。相比于文档对象模型DOM,SAX是读取和操作XML数据的更快速、更轻量的方法。SAX允许在读取文档时处理它,从而不必等待整个文档被存储之后才采取操作,不涉及DOM所必需的开销和概念跳跃。SAX API是一个基于事件的API ,适用于处理数据流,即随着数据的流动而依次处理数据。SAX API在其解析文档时发生一定事件的时候会通知,在响应时,不作保存的数据将会被抛弃[^3]。 以下是简单示例代码展示SAX解析XML: ```java import org.xml.sax.Attributes; import org.xml.sax.SAXException; import org.xml.sax.helpers.DefaultHandler; import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXParserFactory; // 自定义SAX解析处理器 class MyHandler extends DefaultHandler { @Override public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException { System.out.println("开始元素: " + qName); } @Override public void endElement(String uri, String localName, String qName) throws SAXException { System.out.println("结束元素: " + qName); } @Override public void characters(char[] ch, int start, int length) throws SAXException { String data = new String(ch, start, length).trim(); if (!data.isEmpty()) { System.out.println("元素内容: " + data); } } } public class SAXParserExample { public static void main(String[] args) { try { // 创建SAX解析器工厂 SAXParserFactory factory = SAXParserFactory.newInstance(); // 创建SAX解析器 SAXParser saxParser = factory.newSAXParser(); // 创建自定义处理器 MyHandler handler = new MyHandler(); // 解析XML文件 saxParser.parse("your_xml_file.xml", handler); } catch (Exception e) { e.printStackTrace(); } } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

打代码的苏比特

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值