java解析WebService发来的xml内容

 WebService的接口交换中是以xml为标准进行交互,一开始不明白到底是怎么交互,以xml对象为参数?传送xml文件?还是以xml字符串进行交互?最后看了对方给的文档才发现是以xml字符串进行交互,对方发送xml格式的字符串过来,这边只需要解析xml格式的字符串就可以了。那么问题来了,如何高效解析xml字符串。需要强调的一点是节点的名字不能直接为数字,所以我将01改成了E01。

在网上发现有两种方法获取节点信息:

xml内容为:

<?xml version="1.0" encoding="UTF-8"?>  
<body>
  <head>
    <userid>test</userid>
    <password>123</password>
    <trans_no>E01</trans_no>
  </head>
  <request>
    <E01>
    	<ROKKEY>123456789</ROKKEY>
    	<text>衬衫的价格是?</text>
    </E01>
  </request>
</body>

方式一:

Document document=null;
try {
document=DocumentHelper.parseText(xmlstr);
} catch (DocumentException e) {
e.printStackTrace();
}
//获取根元素
Element root=document.getRootElement();
System.out.println("root:"+root);
//获取根元素下的所有子元素
List<Element> list=root.elements();
list=list.get(1).elements();
System.out.println("ROWKEY:"+list.get(0).elementText("ROWKEY"));
System.out.println("TEXT:"+list.get(0).elementText("TEXT"));
方式二:

	public static final String ROWKEY_PATH="body/request/E01/ROWKEY";
	public static final String TEXT_PATH="body/request/E01/TEXT";
	......
		Document document=null;
		try {
			document=DocumentHelper.parseText(xmlstr);
		} catch (DocumentException e) {
			e.printStackTrace();
		}
		String ROWKEY=document.selectSingleNode(ROWKEY_PATH).getText();
		String TEXT=document.selectSingleNode(TEXT_PATH).getText();
		System.out.println("ROWKEY"+ROWKEY);
		System.out.println("TEXT"+TEXT);
其中,方式一只需要引入 dom4j的jar包,方式二需要引入dom4j和jaxen两个jar包。可以看出方式一需要搞清楚xml文档的结构,如果结构发生变化很难维护。方式二中节点顺序写成静态变量格式,方便修改而且不是很复杂。

猜你喜欢

转载自blog.csdn.net/henrymrz/article/details/79153059