dom4j java对象_dom4j解析XML成对象

最近不太忙,发现现在服务之间的交互都是通过xml进行的,所以今天理了一下xml的两种解析方式。首先是最流行的dom4j解析。先解析,然后通过反射转成对象。

用到的jar:dom4j-1.6.1.jar jaxen-1.1.1.jar

1.xml字符串转成对象:

class="java" name="code">

/**

* 解析XMl字符串数据,转化成对象,并返回

* @param xml xml字符串数据

* @param xpathPattern xpath的匹配模式;具体语法请查XPath的语法

* @param classType 要转化对象的类型

* @return 返回用xml数据实例化之后的对象

*/

@SuppressWarnings({ "unchecked", "rawtypes" })

public static Object parseXmlStr(String xml, String xpathPattern, Class classType)

{

try

{

Document doc = DocumentHelper.parseText(xml);

List nodes = doc.selectNodes(xpathPattern);

// Element root = doc.getRootElement();

// List nodes = root.selectNodes("user");

List objs = new ArrayList();

for(Node node : nodes)

{

Map map = traverse(node);

if(classType == String.class)

{

objs.add(map.values().toArray()[0]);

}

else

{

objs.add(nodeToBean(map, classType));

}

}

return objs;

}

catch(Exception e)

{

e.printStackTrace();

return null;

}

}

2.解析xml文件转成对象:

/**

* 解析XMl文件,转化成对象,并返回

* @param xmlPath:xml文件路径(绝对路径)

* @param xpathPattern xpath的匹配模式;具体语法请查XPath的语法

* @param classType 要转化对象的类型

* @return 返回用xml数据实例化之后的对象

*/

@SuppressWarnings({ "unchecked", "rawtypes" })

public static Object parseXmlFile(String xmlPath, String xpathPattern, Class classType)

{

try {

SAXReader reader = new SAXReader();

Document doc = reader.read(new File(xmlPath));

List nodes = doc.selectNodes(xpathPattern);

List objs = new ArrayList();

for(Node node : nodes)

{

Map map = traverse(node);

if(classType == String.class)

{

objs.add(map.values().toArray()[0]);

}

else

{

objs.add(nodeToBean(map, classType));

}

}

return objs;

} catch (DocumentException e) {

e.printStackTrace();

return null;

} catch (Exception e) {

e.printStackTrace();

return null;

}

}

3.用到的辅助方法:

/**

* 从找出的Node节点开始,遍历所有子节点,获取子节点的数据

* @param node:Node节点

* @return 返回节点的值

*/

private static Map traverse(Node node)

{

Map map = new HashMap();

if(node instanceof Element)

{

map = treeWalk((Element)node, map);

}

else

{

map.put(node.getName(), node.getText());

}

return map;

}

/**

* 递归法提取节点的值

* @param element: 节点

* @param map: 保存节点的值

*/

private static Map treeWalk(Element element, Map map)

{

//遍历该元素自身的属性

int as= element.attributeCount();

for(int j=0;j map, Class classType) throws Exception

{

Field[] fields = classType.getDeclaredFields();//返回该类型的所有子属性(包含他继承的类和接口的)

Object obj = classType.getConstructor().newInstance();//创建该类型的实例

for(Field field : fields)

{

//属性名

String fieldName = field.getName();

if(!map.containsKey(fieldName))

{

continue;

}

//因为解析出来都是String类型的,所以创建一个String类型转换成field.getType类型的构造器

Constructor> con = field.getType().getConstructor(String.class);//

Object param = con.newInstance(map.get(fieldName));//通过构造器把字符串转换成field.getType类型的实例

fieldName = fieldName.substring(0, 1).toUpperCase() + fieldName.substring(1);//首字母大写

//根据方法的命名规范,获取该属性的set方法

String methodName = "set" + fieldName;

Method method = classType.getMethod(methodName, field.getType());//获取setter方法把值set到对象实例中

method.invoke(obj, param);

}

return obj;

}

4.测试方法:

public static void main(String[] args) {

String xml = ""+

"123345"+

"duansha0327duansha"+

"zhangdaihaomima"+

"";

String xmlPath = "D:/testXml/user.xml";

// List us = (List) Dom4jXml.parseXmlStr(xml, "/users/user[last()]", User.class);

List us = (List) Dom4jXml.parseXmlFile(xmlPath, "/users/user[last()]", User.class);

if(null != us && us.size()>0)

{

for(User u:us)

{

System.out.println("Id="+u.getId()+" ;userName="+u.getUsername()+" ;passWord"+u.getPassword());

}

}

else

{

System.out.println("解析失败...");

}

}

5.XPath的语法参考:http://www.w3school.com.cn/xpath/xpath_syntax.asp

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用dom4j解析xml对象的步骤如下: 1.引入dom4j的jar包 2.创建SAXReader对象 3.使用SAXReader的read方法读取xml文件,生Document对象 4.获取根节点 5.遍历根节点的子节点,将每个节点的属性值封装到对应的Java对象中 下面是一个示例代码: ``` // 引入dom4j的jar包 import org.dom4j.Document; import org.dom4j.Element; import org.dom4j.io.SAXReader; // 定义Java对象 public class Person { private String name; private int age; // getter和setter方法 } // 解析xml文件生对象的方法 public static List<Person> parseXml(String filePath) throws Exception { List<Person> personList = new ArrayList<>(); SAXReader saxReader = new SAXReader(); Document document = saxReader.read(new File(filePath)); Element rootElement = document.getRootElement(); List<Element> personElements = rootElement.elements("person"); for (Element personElement : personElements) { Person person = new Person(); person.setName(personElement.attributeValue("name")); person.setAge(Integer.parseInt(personElement.attributeValue("age"))); personList.add(person); } return personList; } ``` 在上述示例代码中,我们定义了一个Person类,并且编写了一个parseXml方法用于解析xml文件并生Person对象。在方法中,我们首先创建了一个SAXReader对象,然后使用它的read方法读取xml文件并生Document对象。接着,我们获取了xml文件的根节点,并遍历了它的所有子节点。在遍历过程中,我们使用每个节点的属性值来初始化一个Person对象,并将它添加到personList中。最后,我们返回personList,即可得到解析后的结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值