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