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文档的结构,如果结构发生变化很难维护。方式二中节点顺序写成静态变量格式,方便修改而且不是很复杂。

已标记关键词 清除标记
相关推荐
部分代码如下: public class DomXMLString { private static String SERVICES_HOST = "www.webxml.com.cn"; private static String NETDATA_URL = "http://183.131.242.70:8089/ship/interface/shipInfoService.asmx/getTask"; private static String LOCAL_PC_SAVEFILE_URL = "E:Myeclipse/sy_Task.xml"; private DomXMLString(){} public static void main(String[] args)throws Exception { Document document = getTask(NETDATA_URL); helloOK(document,LOCAL_PC_SAVEFILE_URL); } private static Document getTask(String netXMLDataURL) { Document document = null; DocumentBuilderFactory documentBF = DocumentBuilderFactory.newInstance(); documentBF.setNamespaceAware(true); try{ DocumentBuilder documentB = documentBF.newDocumentBuilder(); InputStream inputStream = getSoapInputStream(netXMLDataURL); document = documentB.parse(inputStream); inputStream.close(); }catch(DOMException e){ e.printStackTrace(); return null; }catch(ParserConfigurationException e){ e.printStackTrace(); return null; }catch(SAXException e){ e.printStackTrace(); return null; }catch(IOException e){ e.printStackTrace(); return null; } return document; } 运行提示错误为: java.io.IOException: Server returned HTTP response code: 500 for URL: http://183.131.242.70:8089/ship/interface/shipInfoService.asmx/getTask at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1626) at org.tempuri.DomXMLString.getSoapInputStream(DomXMLString.java:79) at org.tempuri.DomXMLString.getTask(DomXMLString.java:52) at org.tempuri.DomXMLString.main(DomXMLString.java:39) Exception in thread "main" java.lang.IllegalArgumentException: InputStream cannot be null at javax.xml.parsers.DocumentBuilder.parse(DocumentBuilder.java:117) at org.tempuri.DomXMLString.getTask(DomXMLString.java:53) at org.tempuri.DomXMLString.main(DomXMLString.java:39) 之前也查了一些资料,想请问是不是我设置的路径有问题以及解决办法,求大神指点迷津
©️2020 CSDN 皮肤主题: 精致技术 设计师:CSDN官方博客 返回首页