public static Map xml2map(String xmlString) throws DocumentException {
Document doc = DocumentHelper.parseText(xmlString);
Element rootElement = doc.getRootElement();
Map map = new HashMap();
ele2map(map, rootElement);
System.out.println(map);
return map;
}
private static void ele2map(Map map, Element ele) {
// 获得当前节点的子节点
List elements = ele.elements();
if (elements.size() == 0) {
// 没有子节点说明当前节点是叶子节点,直接取值即可
String val = ele.getText();
if (!StringUtils.isEmpty(val)) {
map.put(ele.getName(), val);
}
} else if (elements.size() == 1) {
// 只有一个子节点说明不用考虑list的情况,直接继续递归即可
Map tempMap = new HashMap();
ele2map(tempMap, elements.get(0));
map.put(ele.getName(), tempMap);
} else {
// 多个子节点的话就得考虑list的情况了,比如多个子节点有节点名称相同的
// 构造一个map用来去重
Map tempMap = new HashMap();
for (Element element : elements) {
tempMap.put(element.getName(), null);
}
Set keySet = tempMap.keySet();
for (String string : keySet) {
Namespace namespace = elements.get(0).getNamespace();
List elements2 = ele.elements(new QName(string, namespace));
// 如果同名的数目大于1则表示要构建list
if (elements2.size() > 1) {
List> list = new ArrayList>();
for (Element element : elements2) {
Map tempMap1 = new HashMap();
ele2map(tempMap1, element);
list.add(tempMap1);
}
map.put(string, list);
} else {
// 同名的数量不大于1则直接递归去
Map tempMap1 = new HashMap();
ele2map(tempMap1, elements2.get(0));
String kry = (String) tempMap1.get(string);
//如果是空的 会是list节点
if(StringUtils.isEmpty(kry)){
map.put(string, tempMap1);
}else{
map.put(string, kry);
}
}
}
}
}