xml文档的解析并通过工具类实现java实体类的映射:XML工具-XmlUtil
若有疑问,可以联系我本人微信:Y1141100952
声明:本文章为原稿,转载必须说明 本文章地址,否则一旦发现,必追究法律责任
1:本文章显示通过 XML工具-XmlUtil工具实现解析soap报文的xml格式文档的解析,取出里面的数据,放到map的key-value的集合里面,在使用另外的一个工具类实现map映射成java的实体类。本人亲自做过是可以实现的。文档最后会附上soap.xml文档,以供参考。
2: XML工具-XmlUtil的使用说明:(网址:https://hutool.cn/docs/#/core/%E5%B7%A5%E5%85%B7%E7%B1%BB/XML%E5%B7%A5%E5%85%B7-XmlUtil)
pom.xml依赖如下:
<!--hutool工具类-->
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
<version>4.5.15</version>
</dependency>
主要的方法是:XmlUtil.getElements(elements, null);
第一个参数是传入的节点,以得到elements下的所有节点
第二个参数是获取elements下的指定节点以得到数据。如果为null,那么会返回elements下的所有节点。
开始进行报文的解析:
1:首先获取根节点:使用如下的代码即可获取
import org.w3c.dom.Document;
import org.w3c.dom.Element;
// 解析报文得到根节点
Document document = XmlUtil.parseXml(xml); //xml参数为String类型的xml报文,如果是现成的xml文档,你们可以用文件流读取出来再转为String类型
Element root = XmlUtil.getRootElement(document); 2:得到根节点之后,我们再拿根节点调用前文说的主要方法
//根据root得到的根节点,调用下面的方法获得Header ,Body节点
List<Element> elementList1 = XmlUtil.getElements(root, null); 3:我们得到了 Header ,Body节点,但是我们不需要解析Header节点,只需要解析Body节点,故我们继续调用
//根据 elementList1.get(1)取出Body节点 ,获得其下节点:Response
List<Element> elementList2 = XmlUtil.getElements(elementList1.get(1), null);
4.。。。。。。因为soap xml文档解析结构跟你们的不一样,故我只列出我做的,反正不断的调用 方法即可获取指定节点下的所有元素,一步一步的调用:
XmlUtil.getElements(element, null);
我的完整代码如下:
// 解析报文
Document document = XmlUtil.parseXml(xml);
Element root = XmlUtil.getRootElement(document); //获得Header ,Body节点
List<Element> elementList1 = XmlUtil.getElements(root, null); //根据Body ,获得其下节点:Response
List<Element> elementList2 = XmlUtil.getElements(elementList1.get(1), null); //根据Response节点,又获取得到 ES_BASEINFO、ES_MESSAGE两个节点
List<Element> elementList3 = XmlUtil.getElements(elementList2.get(0), null); //根据ES_MESSAGE 节点,获取得到其下的 XM(项目)、FQ(分期)、LD(楼栋)、MJZB(面积指标)四个节点
List<Element> elementList4 = XmlUtil.getElements(elementList3.get(1), null);
//获取项目数据
elementList4.stream().forEach(xmElement -> {
//判断是否是项目的节点 ,常量SoapXmlConstant.XM是我自己定义的常量: XM
if (xmElement.getNodeName().equals(SoapXmlConstant.XM)) {
//获得XM所有子节点,可能包括:XM_MD0006、XM_MD0007、XM_MD0012、XM_MD0010
List<Element> xmNodeElement = XmlUtil.getElements(xmElement, null);
xmNodeElement.stream().forEach(xmChildNode -> {
//如果是子节点:XM_MD0006(因为其数据结构跟XM_MD0007、XM_MD0012、XM_MD0010节点不一样,故分离开)
if (xmChildNode.getNodeName().equals(SoapXmlConstant.XM_MD0006)) {
List<Element> xm006DetailElements = XmlUtil.getElements(xmChildNode, null);
xm006DetailElements.stream().forEach(data -> {
xm0006.put(data.getNodeName(), data.getTextContent());
});
xm0006MapList.add(xm0006);
xmMap.put(SoapXmlConstant.XM_MD0006, xm0006MapList);
} else {
if (xmChildNode.getNodeName().equals(SoapXmlConstant.XM_MD0007)) {
//XM_MD0007
List<Element> itemElements = XmlUtil.getElements(xmChildNode, null);
itemElements.stream().forEach(items -> {
Map<String, String> xm0007 = new HashMap<>(); //保存项目的XM_MD0007数据 key-value
List<Element> itemDetailElements = XmlUtil.getElements(items, null);
itemDetailElements.stream().forEach(data -> {
//获得了每个item下的子节点,遍历数据,保存数据
xm0007.put(data.getNodeName(), data.getTextContent());
});
xm0007MapList.add(xm0007);
});
xmMap.put(SoapXmlConstant.XM_MD0007, xm0007MapList);
} else if (xmChildNode.getNodeName().equals(SoapXmlConstant.XM_MD0010)) {
//XM_MD0010
List<Element> itemElements = XmlUtil.getElements(xmChildNode, null);
itemElements.stream().forEach(items -> {
Map<String, String> xm0010 = new HashMap<>(); //保存项目的XM_MD0010数据 key-value
List<Element> itemDetailElements = XmlUtil.getElements(items, null);
itemDetailElements.stream().forEach(data -> {
//获得了每个item下的子节点,遍历数据,保存数据
xm0010.put(data.getNodeName(), data.getTextContent());
});
xm0010MapList.add(xm0010);
});
xmMap.put(SoapXmlConstant.XM_MD0010, xm0010MapList);
} else if (xmChildNode.getNodeName().equals(SoapXmlConstant.XM_MD0021)) {
//XM_MD0021
List<Element> itemElements = XmlUtil.getElements(xmChildNode, null);
itemElements.stream().forEach(items -> {
Map<String, String> xm0021 = new HashMap<>(); //保存项目的XM_MD0012数据 key-value
List<Element> itemDetailElements = XmlUtil.getElements(items, null);
itemDetailElements.stream().forEach(data -> {
//获得了每个item下的子节点,遍历数据,保存数据
xm0021.put(data.getNodeName(), data.getTextContent());
});
xm0021MapList.add(xm0021);
});
xmMap.put(SoapXmlConstant.XM_MD0021, xm0023MapList);
} else if (xmChildNode.getNodeName().equals(SoapXmlConstant.XM_MD0023)) {
//XM_MD0023
List<Element> itemElements = XmlUtil.getElements(xmChildNode, null);
itemElements.stream().forEach(items -> {
Map<String, String> xm0023 = new HashMap<>(); //保存项目的XM_MD0012数据 key-value
List<Element> itemDetailElements = XmlUtil.getElements(items, null);
itemDetailElements.stream().forEach(data -> {
//获得了每个item下的子节点,遍历数据,保存数据
xm0023.put(data.getNodeName(), data.getTextContent());
});
xm0023MapList.add(xm0023);
});
xmMap.put(SoapXmlConstant.XM_MD0023, xm0023MapList);
} else {
//XM_MD0012
List<Element> itemElements = XmlUtil.getElements(xmChildNode, null);
itemElements.stream().forEach(items -> {
Map<String, String> xm0012 = new HashMap<>(); //保存项目的XM_MD0012数据 key-value
List<Element> itemDetailElements = XmlUtil.getElements(items, null);
itemDetailElements.stream().forEach(data -> {
//获得了每个item下的子节点,遍历数据,保存数据
xm0012.put(data.getNodeName(), data.getTextContent()); //key-value,保证后面的实体类映射map能映射数据
});
xm0012MapList.add(xm0012);
});
xmMap.put(SoapXmlConstant.XM_MD0012, xm0012MapList);
}
}
});
}
dataMap.put(SoapXmlConstant.XM, xmMap);
});
map集合映射成java实体类如下:(只有一个方法,调用即可)
pom.xml依赖如下:
<dependency>
<groupId>commons-beanutils</groupId>
<artifactId>commons-beanutils</artifactId>
<version>1.9.3</version>
</dependency>
完整代码如下:(就这么简单:本人已经实现)
StagingMD0023 stagingMD0023 = new StagingMD0023(); //要映射map集合到的实体类
try {
BeanUtils.populate(stagingMD0023, fqMD0023);
//参数一:实体类,参数二:map集合
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}
soap.xml文档百度云网盘如下:
链接:https://pan.baidu.com/s/1d1m3Aao8RTCXtE920ZBcZQ
提取码:tsi4
若有疑问,可以联系我本人微信:Y1141100952
xml文档的解析并通过工具类实现java实体类的映射:XML工具-XmlUtil的更多相关文章
- Java解析XML文档——dom解析xml
一.前言 用Java解析XML文档,最常用的有两种方法:使用基于事件的XML简单API(Simple API for XML)称为SAX和基于树和节点的文档对象模型(Document Object M ...
- DOM生成XML文档与解析XML文档(JUNIT测试)
package cn.liuning.test; import java.io.File; import java.io.IOException; import javax.xml.parsers.D ...
- javaweb学习总结十三(dom4j方式对XML文档进行解析以及Xpath的使用)
一:dom4j方式介绍 对于xml的解析总共有三种 1:jaxp方式,是sun公司开发的,分为sax方式和dom方式 2:jdom方式,后来其中部分人员参与开发dom4j 3:dom4j方式,是现在企 ...
- Java开发知识之XML文档使用,解析
目录 XML文件详解 一丶XML简介 1.文档结构 2.XML中的元素(Element)或者叫做标签(Tab).属性 文本内容. 节点(Node) 3.XML语法规则 二丶XML文档解析 三丶使用XP ...
- QT XML文档的解析 QXmlStreamReader, DOM,SAX 三种解析方法 简单示例
0. xml文档如下 <?xml version="1.0"?> <bookindex> <entry term="sidebearings ...
- XML文档的解析—dom4j
XML为可扩展标记语言,它主要是用来保存数据,做配置文件,数据传输载体等.其实就是一个后缀名为.xml的文件. XML命名规则 名称可以含字母.数字以及其他的字符 名称不能以数字或者标点符号开始 名称 ...
- c# 创建XML文档,解析XML文档
1.静态函数 using System; using System.Collections.Generic; using System.Linq; using System.Text; using S ...
- web api .net C# mvc API返回XML文档的解析并取值
[HttpGet] public System.Net.Http.HttpResponseMessage GetNotify() { var xmlstring = @" <xml&g ...
- XML反序列化出错,XML 文档(2, 2)中有错误
XML转换为实体类的错误处理方案 一.错误描述: XML反序列化出错,XML 文档(2, 2)中有错误 二.解决方案: 在实体类的字段要加上XmlElement属性 三.具体实现: 1.XML文档 & ...
随机推荐
- Container killed by YARN for exceeding memory limits
19/08/12 14:15:35 ERROR cluster.YarnScheduler: Lost executor 5 on worker01.hadoop.mobile.cn: Contain ...
- Math和Date
Math和Date 一.对象 1.对象的概念 对象的本质:键值对,属性名和属性值 对象的意义:存储数据,编程 对象中的变量:属性 对象中的函数:方法 2.对象的赋值 var obj = {}; var ...
- MySQL多表关联数据同时删除
MySQL多表关联时的多表删除: DELETE t1, t2FROM t1LEFT JOIN t2 ON t1.id = t2.idWHERE t1.id = 25
- 常见rpm包和yum包命令
1.rpm包 在 安装.升级.卸载服务程序时要考虑到其他程序.库的依赖关系,在进行校验.安装. 卸载.查询.升级等管理软件操作时难度都非常大. RPM 机制则为解决这些问题而设计的.RPM 有点像 W ...
- c++ 按位或
|=是位操作运算符的一种,其形式为:a|=b代表的含义为a=a|b;即把a和b做按位或(|)操作,结果赋值给a.按位或的计算规则为:1 逐位进行计算:2 计算数的同位上值,如果均为0,则结果对应位上值 ...
- Qt最新版5.12.2在Win10环境静态编译安装和部署的完整过程(VS2017)
一.为什么要静态编译 用QtCreator编译程序时,使用的是动态编译.编译好的程序在运行时需要另外加上相应的Qt库文件,一大堆dll文件.如果想将生成的程序连同所需要的库一起完整地打包成一个可执行程 ...
- 《NVMe-over-Fabrics-1_0a-2018.07.23-Ratified》阅读笔记(1)
1 引言(入门介绍) NVMe版本1.2.1和之前的版本为主机软件与非易失存储系统通过PCIe通信定义了寄存器级接口.本规格说明书定义了对NVMe的扩展,启用通过其他网络互联上的操作(NVMe ove ...
- Java连载22-for循环
一.循环结构 在程序当中总有一些需要反复的/重复的执行的代码,假设没有循环结构,那么这段需要重复执行的代码自然式子最需要重复编写的,代码无法得到重复使用,所以多数编程语言都是支持循环结构的,将来把需要 ...
- Contour 学习笔记(一):使用 Contour 接管 Kubernetes 的南北流量
原文链接:Contour 学习笔记(一):使用 Contour 接管 Kubernetes 的南北流量 在 Kubernetes 中运行大规模以 Web 为中心的工作负载,最关键的需求之一就是在 L7 ...
- Java之Exception
Exception这个东西,程序中必须会有的,尽管我们很不乐意看到它,可是从另一个角度考虑,有异常则说明程序有问题,有助于我们及时改正.有的时候程序出错的原因有很多,比如不合法的输入.类型.空指针甚至 ...