这里使用的是:dom解析。需要导dom4j的包。
Map map = new HashMap();
try {Document parseText = DocumentHelper.parseText(xml);
Element root= parseText.getRootElement();//
Iterator elementIterator = root.elementIterator();//遍历
while(elementIterator.hasNext()){
Element elem = (Element) elementIterator.next();
map.put(elem.getName(), elem.getText());
}
} catch (DocumentException e) {
e.printStackTrace();
}
修改之后的:
@SuppressWarnings({ "rawtypes" })
public static Map parseContent(String excute){
Map map1 = new HashMap();
try {
Document parseText = DocumentHelper.parseText(excute);
Element element = parseText.getRootElement();
map1 = parseXml(element);
} catch (DocumentException e) {
e.printStackTrace();
}
return map1;
}
@SuppressWarnings({ "rawtypes", "unchecked" })
public static Map parseXml(Element element){
Iterator elementIterator = element.elementIterator();
while(elementIterator.hasNext()){
Element elem = (Element) elementIterator.next();
map.put(elem.getName(),elem.getText());
parseXml(elem);
}
return map;
}
这里使用了递归方法parseXml()直到这个方法不满足就不进了。
但是这里有个问题就是有重复结点的话就会覆盖。