dom4j java对象_dom4j解析XML成对象

dom4j java对象_dom4j解析XML成对象最近不太忙,发现现在服务之间的交互都是通过xml进行的,所以今天理了一下xml的两种解析方式。首先是最流行的dom4j解析。先解析,然后通过反射转成对象。用到的jar:dom4j-1.6.1.jarjaxen-1.1.1.jar1.xml字符串转成对象:class=”java”name=”code”>/***解析XMl字符串数据,转化成对象,并返回*@paramxmlxml字符串…

大家好,又见面了,我是你们的朋友全栈君。

最近不太忙,发现现在服务之间的交互都是通过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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/152030.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 按位取反的概念和计算方法「建议收藏」

    按位取反的概念和计算方法「建议收藏」读本文前请首先搞懂 “反码”,“取反”,“按位取反(~)”,这3个概念是不一样的。取反:0变1,1变0反码:正数的反码是其本身,对于负数其符号位不变其它各位取反(0变1,1变0)按位取反(~):这将是下面要讨论的。“~”运算符在c、c++、java、c#中都有,之前一直没有遇到这个运算符。要弄懂这个运算符的计算方法,首先必须明白二进制数在内存中的存放形式,二进制数在内存中是以补码的形式存放的。…

  • H2 数据库简介_polardb 数据库

    H2 数据库简介_polardb 数据库H2数据库H2是使用Java开发的内嵌式数据库,开源。支持内存、文件等多种模式。常用于开发和测试环境。特性读操作快,写操作不如SQLite支持全文检索(提供了内置全文检索和ApacheLuncene的全文检索)可以通过浏览器操作数据库运行模式EmbeddedMode内嵌模式ServerModel服务器模式混合模式下载目前最新版本是1.4.200,于2019/10/14发布。Windows安装版本:https://h2database.co

    2022年10月12日
  • 8000401a 错误 及解决办法[通俗易懂]

    8000401a 错误 及解决办法[通俗易懂]
    “/”应用程序中的服务器错误。
    ——————————————————————————–
    检索COM类工厂中CLSID为{00024500-0000-0000-C000-000000000046}的组件时失败,原因是出现以下错误:8000401a。
    说明:执行当前Web请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以

  • java string分割_java 字符串分割的三种方法(总结)[通俗易懂]

    java string分割_java 字符串分割的三种方法(总结)[通俗易懂]最近在项目中遇到一个小问题,一个字符串分割成一个数组,类似Stringstr=”aaa,bbb,ccc”;然后以”,”为分割符,将其分割成一个数组,用什么方法去实现呢?第一种方法:可能一下子就会想到使用split()方法,用split()方法实现是最方便的,但是它的效率比较低第二种方法:使用效率较高的StringTokenizer类分割字符串,StringTokenizer类是JDK中提供的专…

  • python pyc文件解析_pyc文件

    python pyc文件解析_pyc文件codeobject¶在我们导入python脚本时在目录下会生成个一个相应的pyc文件,是pythoncodeobj的持久化储存形式,加速下一次的装载。文件结构¶pyc文件由三大部分组成最开始4个字节是一个Maigcint,标识此pyc的版本信息接下来四个字节还是个int,是pyc产生的时间序列化的PyCodeObject,结构参照include/code.h,序列化方法pyth…

  • 笔记7 正则(grep、sed、awk工具)

    笔记7 正则(grep、sed、awk工具)

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号