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

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

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

(0)
上一篇 2022年6月21日 上午7:16
下一篇 2022年6月21日 上午7:16


相关推荐

  • 对不起,学会这些 Linux 知识后,我有点飘

    对不起,学会这些 Linux 知识后,我有点飘Linux简介UNIX是一个交互式系统,用于同时处理多进程和多用户同时在线。为什么要说UNIX,那是因为Linux是由UNIX发展而来的,UNIX是由程序员设计,它的主要服务对象也是程序员。Linux继承了UNIX的设计目标。从智能手机到汽车,超级计算机和家用电器,从家用台式机到企业服务器,Linux操作系统无处不在。大多数程序员都喜欢让系统尽量简单,优雅并具有一致性。举个例子,从最底层的角度来讲,一个文件应该只是一个字节集合。为了实现顺序存取、随机存取、按键存取、远程存取只能是

    2022年5月31日
    26
  • 机器学习之K-近邻算法

    1.橙子还是柚子该例子来自于《算法图解》,看下图中的水果是橙子还是柚子?我的思维过程类似于这样:我脑子里面有个图表图中左下的表示橙子,右上的表示柚子,取橙子和柚子的两个特征(大和红),一般而言

    2021年12月30日
    44
  • 没有理想,你和我还有什么区别呢![通俗易懂]

    阳光之中到处可见 奔忙的人们 被拥挤着 被一晃而飞的光阴 忽略过

    2022年2月26日
    70
  • 苹果绿设置zz

    苹果绿设置zz主要是在 linux 用了 google 的浏览器 不知道怎么设置 才找到了这篇文章 XP 系统设置方法 打开控制面板中的 显示 nbsp nbsp nbsp 选择外观 appearance 高级 advanced 然后在项目 items 那栏选窗口 windows 再点颜色 color 其它 others 然后把 Hue 色调 设为 85 Sat 饱和度 设为 90 Lum 亮度 设为 205 然后单击添加到自定义颜色 Addtocustomc 按 确定 一直确定 nbsp nbsp nbsp nbsp nbsp nbsp nbsp WIN7 系统设置方法 跟 XP

    2026年3月18日
    1
  • 解决gitignore不起作用

    解决gitignore不起作用gitignore 中已经标明忽略的文件目录下的文件 gitpush 的时候还会出现在 push 的目录中 原因是因为在 git 忽略目录中 新建的文件在 git 中会有缓存 修改的文件已经被纳入了版本管理中 就算是在 gitignore 中声明了忽略路径也是不起作用的 这时候我们就应该先把本地缓存删除 然后再进行 git 的 push 这样就不会出现忽略的文件了 git 清除本地缓存命令如下 gitr

    2026年3月26日
    2
  • “光猫”调制解调器 和 路由器的区别 傻傻分不清

    “光猫”调制解调器 和 路由器的区别 傻傻分不清一、“猫”指调制解调器,所谓调制,就是把数字信号转换成电话线上传输的模拟信号;解调,即把模拟信号转换成数字信号。合称调制解调器。调制解调器的英文是“Modem”,读音与“猫”相似,因此被称作“猫”。简单来说,“猫”的主要作用是上连宽带线路,下连电脑,实现电脑与宽带的连接,这样电脑才能够正常上网。路由器,又称网关设备,英文名是“Router”,是连接因特网中各局域网、广域网的设备,它会根据信…

    2025年7月12日
    8

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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