import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
public class Dom4j
{
public static Map<String, String> readStringXml(String xml)
{
Document doc = null;
try
{
// 读取并解析XML文档
// SAXReader就是一个管道,用一个流的方式,把xml文件读出来
//
// SAXReader reader = new SAXReader(); //User.hbm.xml表示你要解析的xml文档
// Document document = reader.read(new File("User.hbm.xml"));
// 下面的是通过解析xml字符串的
doc = DocumentHelper.parseText(xml); // 将字符串转为XML
Element rootElt = doc.getRootElement(); // 获取根节点
System.out.println("根节点:" + rootElt.getName()); // 拿到根节点的名称
List<Map<String, String>> list = new ArrayList<>();
recursiveNode(rootElt, list);
List<Map<String, String>> resultList = list;
Map<String, String> retMap = new HashMap<>();
for (int i = 0; i < resultList.size(); i++)
{
Map map = resultList.get(i);
for (Iterator iterator = map.keySet().iterator(); iterator.hasNext();)
{
String key = (String)iterator.next();
retMap.put(key, (String)map.get(key));
}
}
System.out.println("reMap" + retMap);
return retMap;
}
catch (DocumentException e)
{
e.printStackTrace();
}
catch (Exception e)
{
e.printStackTrace();
}
return null;
}
/**
* 递归遍历所有的节点获得对应的值
*
* @param
*/
private static void recursiveNode(Element root, List<Map<String, String>> list)
{
// 遍历根结点的所有孩子节点
HashMap<String, String> map = new HashMap<>();
for (Iterator iter = root.elementIterator(); iter.hasNext();)
{
Element element = (Element)iter.next();
if (element == null)
{
continue;
}
// 获取属性和它的值
for (Iterator attrs = element.attributeIterator(); attrs.hasNext();)
{
Attribute attr = (Attribute)attrs.next();
System.out.println(attr);
if (attr == null)
{
continue;
}
String attrName = attr.getName();
System.out.println("attrname" + attrName);
String attrValue = attr.getValue();
map.put(attrName, attrValue);
}
//如果该节点含有文本数据,也就是叶节点
// 如果有PCDATA,则直接提出
if (element.isTextOnly())
{
String innerName = element.getName();
String innerValue = element.getText();
map.put(innerName, innerValue);
list.add(map);
}
else
{
// 递归调用
recursiveNode(element, list);
}
}
}
}
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
public class Dom4j
{
public static Map<String, String> readStringXml(String xml)
{
Document doc = null;
try
{
// 读取并解析XML文档
// SAXReader就是一个管道,用一个流的方式,把xml文件读出来
//
// SAXReader reader = new SAXReader(); //User.hbm.xml表示你要解析的xml文档
// Document document = reader.read(new File("User.hbm.xml"));
// 下面的是通过解析xml字符串的
doc = DocumentHelper.parseText(xml); // 将字符串转为XML
Element rootElt = doc.getRootElement(); // 获取根节点
System.out.println("根节点:" + rootElt.getName()); // 拿到根节点的名称
List<Map<String, String>> list = new ArrayList<>();
recursiveNode(rootElt, list);
List<Map<String, String>> resultList = list;
Map<String, String> retMap = new HashMap<>();
for (int i = 0; i < resultList.size(); i++)
{
Map map = resultList.get(i);
for (Iterator iterator = map.keySet().iterator(); iterator.hasNext();)
{
String key = (String)iterator.next();
retMap.put(key, (String)map.get(key));
}
}
System.out.println("reMap" + retMap);
return retMap;
}
catch (DocumentException e)
{
e.printStackTrace();
}
catch (Exception e)
{
e.printStackTrace();
}
return null;
}
/**
* 递归遍历所有的节点获得对应的值
*
* @param
*/
private static void recursiveNode(Element root, List<Map<String, String>> list)
{
// 遍历根结点的所有孩子节点
HashMap<String, String> map = new HashMap<>();
for (Iterator iter = root.elementIterator(); iter.hasNext();)
{
Element element = (Element)iter.next();
if (element == null)
{
continue;
}
// 获取属性和它的值
for (Iterator attrs = element.attributeIterator(); attrs.hasNext();)
{
Attribute attr = (Attribute)attrs.next();
System.out.println(attr);
if (attr == null)
{
continue;
}
String attrName = attr.getName();
System.out.println("attrname" + attrName);
String attrValue = attr.getValue();
map.put(attrName, attrValue);
}
//如果该节点含有文本数据,也就是叶节点
// 如果有PCDATA,则直接提出
if (element.isTextOnly())
{
String innerName = element.getName();
String innerValue = element.getText();
map.put(innerName, innerValue);
list.add(map);
}
else
{
// 递归调用
recursiveNode(element, list);
}
}
}
}