import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
@SuppressWarnings("rawtypes")
public class SoapXmlUtil {
public Map<String, String> map = new HashMap<String, String>();
public Map<String, String> ParseSoapXml(String SoapXml) {
try {
Document document = DocumentHelper.parseText(SoapXml);
Element elements = document.getRootElement();
Iterator iterators = elements.elementIterator();
// 获取根节点中的信息
while (iterators.hasNext()) {
Element element = (Element) iterators.next();
String name = element.getName();
// 一般Header节点中是空的
if (name.equals("Body")) {
Iterator iterator = element.elementIterator();
this.ParseDom(iterator);
}
}
} catch (DocumentException e) {
e.printStackTrace();
}
return map;
}
// 获取具体key-value
private void ParseDom(Iterator iterators) {
while (iterators.hasNext()) {
Element element = (Element) iterators.next();
Iterator iterator = element.elementIterator();
if (iterator.hasNext()) {
this.ParseDom(iterator);
} else {
String key = element.getName();
String value = element.getStringValue();
map.put(key, value);
}
}
}
}
Soap报文解析
最新推荐文章于 2022-07-05 10:29:47 发布
该博客介绍了如何利用Java的DOM4J库解析SOAP XML报文。通过创建`SoapXmlUtil`类,定义了`ParseSoapXml`方法,将SOAP XML字符串转换为Map,提取出Body节点中的键值对信息。在解析过程中,遍历XML元素并递归处理子节点,最终将键值对存储到HashMap中。
1万+

被折叠的 条评论
为什么被折叠?



