加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

解析XML的两种方式 javax | dom4j

发布时间:2020-12-16 06:34:51 所属栏目:百科 来源:网络整理
导读:package xml;import java.io.IOException;import java.io.StringReader;import java.util.HashMap;import java.util.List;import java.util.Map;import org.dom4j.DocumentException;public class Test { private static String xml = "xmlToUserName![CDATA
package xml;

import java.io.IOException;
import java.io.StringReader;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.dom4j.DocumentException;

public class Test {
    private static String xml = "<xml><ToUserName><![CDATA[gh_3e8adccde292]]></ToUserName><FromUserName><![CDATA[oR5Gjjl_eiZoUpGozMo7dbBJ362A]]></FromUserName><CreateTime>1394524295</CreateTime><MsgType><![CDATA[event]]></MsgType><Event><![CDATA[MASSSENDJOBFINISH]]></Event><MsgID>1988</MsgID><Status><![CDATA[sendsuccess]]></Status><TotalCount>100</TotalCount><FilterCount>80</FilterCount><SentCount>75</SentCount><ErrorCount>5</ErrorCount></xml>";

    public static void main(String[] args) throws javax.xml.parsers.ParserConfigurationException,org.xml.sax.SAXException,IOException,DocumentException {
        Map<String,String> map = praseXml2(xml);
        for (String key : map.keySet()) {
            System.out.println("[key] " + key + "   [value] " + map.get(key) + "");
        }
    }

    /**
     * dom4j解析xml
     * 
     * @param xml xmlString
     * @return map
     * @throws org.dom4j.DocumentException dom4j异常
     */
    private static Map<String,String> praseXml2(String xml) throws org.dom4j.DocumentException {
        Map<String,String> map = new HashMap<String,String>();
        // 读取输入流
        org.dom4j.io.SAXReader reader = new org.dom4j.io.SAXReader();
        //读取XML
        StringReader sr = new StringReader(xml);
        //XML 实体的单一输入源
        org.xml.sax.InputSource is = new org.xml.sax.InputSource(sr);
        org.dom4j.Document document = reader.read(is);
        // 得到xml根元素
        org.dom4j.Element root = document.getRootElement();
        // 得到根元素的所有子节点
        List<org.dom4j.Element> elementList = root.elements();
        // 遍历所有子节点
        for (org.dom4j.Element e : elementList)
            map.put(e.getName(),e.getText());
        return map;
    }

    /**
     * 利用javax.xml |org.w3c 解析XML文档
     * 
     * @param xml xml文档
     * @return 解析结果
     * @throws ParserConfigurationException 配置异常
     * @throws SAXException XML解析异常
     * @throws IOException IO异常
     */
    private static Map<String,String> praseXml(String xml) throws javax.xml.parsers.ParserConfigurationException,IOException {
        //导入的包

        Map<String,String>();
        //定义工厂 API,使应用程序能够从 XML 文档获取生成 DOM 对象树的解析器。
        javax.xml.parsers.DocumentBuilderFactory dbf;
        //获取 DocumentBuilderFactory 的新实例。
        dbf = javax.xml.parsers.DocumentBuilderFactory.newInstance();
        //从 XML 获取一个 Document
        javax.xml.parsers.DocumentBuilder db;
        //使用dbf当前配置的参数创建一个新的 DocumentBuilder 实例。
        db = dbf.newDocumentBuilder();
        //读取XML
        StringReader sr = new StringReader(xml);
        //XML 实体的单一输入源
        org.xml.sax.InputSource is = new org.xml.sax.InputSource(sr);
        //定义org.w3c.dom.Document 接口
        org.w3c.dom.Document document;
        //将给定输入源的内容解析为一个 XML 文档,并且返回一个新的 DOM Document 对象。
        document = db.parse(is);
        //Element 接口表示 XML 文档中的一个元素,根节点
        org.w3c.dom.Element root;
        //允许直接访问文档的文档元素的子节点 
        root = document.getDocumentElement();
        //获得包含此节点的所有子节点的 NodeList
        org.w3c.dom.NodeList nodelist = root.getChildNodes();
        //获得所有节点的名称与值
        for (int i = 0; i < nodelist.getLength(); i++) {
            String key = nodelist.item(i).getNodeName();
            String value = nodelist.item(i).getTextContent();
            map.put(key,value);
        }
        //返回键值对
        return map;
    }
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读