您的位置:首页 > 编程语言 > Java开发

解析XML的两种方式 javax | dom4j

2014-12-04 19:08 375 查看
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,
org.xml.sax.SAXException, IOException {
//导入的包

Map<String, String> map = new HashMap<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;
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: