Dom4j解析xml复杂多节点报文
XML是一种通用的数据交换格式,它的平台无关性、语言无关性、系统无关性、给数据集成与交互带来了极大的方便。XML在不同的语言环境中解析方式都是一样的,只不过实现的语法不同而已。
XML的解析方式分为四种
1、DOM解析
2、SAX解析
3、JDOM解析
4、DOM4J解析
其中前两种属于基础方法,是官方提供的平台无关的解析方式;后两种属于扩展方法,它们是在基础的方法上扩展出来的,只适用于java平台。
本文介绍的是DOM4J方式解析
依赖jar包:
1
2
3
4
5
|
< dependency > < groupId >dom4j</ groupId > < artifactId >dom4j</ artifactId > < version >1.6.1</ version > </ dependency > |
xml报文如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
|
<? xml version = "1.0" encoding = "UTF-8" standalone = "yes" ?> < Root > < SttlCntNb >2</ SttlCntNb > < DebitCntAmt >CNY0.00</ DebitCntAmt > < CreditCntAmt >CNY4700.00</ CreditCntAmt > < SttlList > < SttlInf > < SttlReptFlg >2018052500170139</ SttlReptFlg > < SttlDCFlg >2</ SttlDCFlg > < SttlAmt >CNY100.00</ SttlAmt > < BatchList > < BatchInf > < BatchId >B201805230015</ BatchId > < BatchDCFlg >2</ BatchDCFlg > < BatchNetAmt >CNY100.00</ BatchNetAmt > < SubItemList > < SubItemInf >0113|C3228644000018|04|CNY0.00|0|CNY5.00|1|</ SubItemInf > < SubItemInf >0120|C3228640000020|05|CNY50.00|1|CNY0.00|0|</ SubItemInf > < SubItemInf >0114|C3228640000029|07|CNY0.00|0|CNY5.00|1|</ SubItemInf > < SubItemInf >0115|C3228640000019|06|CNY0.00|0|CNY5.00|1|</ SubItemInf > < SubItemInf >0111|C3228640000016|03|CNY0.00|0|CNY10.00|1|</ SubItemInf > < SubItemInf >0110|C3228644000016|01|CNY0.00|0|CNY110.00|1|</ SubItemInf > < SubItemInf >0112|C3228644000017|99|CNY0.00|0|CNY5.00|1|</ SubItemInf > < SubItemInf >0110|C3228644000016|02|CNY0.00|0|CNY10.00|1|</ SubItemInf > </ SubItemList > </ BatchInf > </ BatchList > </ SttlInf > < SttlInf > < SttlReptFlg >2018052500170138</ SttlReptFlg > < SttlDCFlg >2</ SttlDCFlg > < SttlAmt >CNY4600.00</ SttlAmt > < BatchList > < BatchInf > < BatchId >B201805240001</ BatchId > < BatchDCFlg >2</ BatchDCFlg > < BatchNetAmt >CNY400.00</ BatchNetAmt > < SubItemList > < SubItemInf >0126|C1010511003703|00|CNY0.00|4|CNY0.00|0|</ SubItemInf > < SubItemInf >0125|C1010211000012|01|CNY0.00|8|CNY0.00|0|</ SubItemInf > < SubItemInf >0126|C1010211000012|01|CNY0.00|8|CNY0.00|0|</ SubItemInf > < SubItemInf >0124|C1010211000012|01|CNY0.00|8|CNY0.00|0|</ SubItemInf > < SubItemInf >0123|C1010211000012|01|CNY0.00|4|CNY0.00|0|</ SubItemInf > < SubItemInf >0110|C1010211000012|01|CNY0.00|0|CNY400.00|2|</ SubItemInf > </ SubItemList > </ BatchInf > < BatchInf > < BatchId >B201805240002</ BatchId > < BatchDCFlg >2</ BatchDCFlg > < BatchNetAmt >CNY400.00</ BatchNetAmt > < SubItemList > < SubItemInf >0125|C1010211000012|00|CNY400.00|4|CNY0.00|0|</ SubItemInf > < SubItemInf >0110|C1010211000012|00|CNY0.00|0|CNY800.00|2|</ SubItemInf > </ SubItemList > </ BatchInf > < BatchInf > < BatchId >B201805240003</ BatchId > < BatchDCFlg >1</ BatchDCFlg > < BatchNetAmt >CNY0.00</ BatchNetAmt > < SubItemList > < SubItemInf >0120|C1010211000012|00|CNY0.00|4|CNY0.00|0|</ SubItemInf > </ SubItemList > </ BatchInf > < BatchInf > < BatchId >B201805240004</ BatchId > < BatchDCFlg >2</ BatchDCFlg > < BatchNetAmt >CNY1200.00</ BatchNetAmt > < SubItemList > < SubItemInf >0112|C1010211000012|01|CNY0.00|0|CNY1200.00|2|</ SubItemInf > </ SubItemList > </ BatchInf > < BatchInf > < BatchId >B201805240005</ BatchId > < BatchDCFlg >2</ BatchDCFlg > < BatchNetAmt >CNY400.00</ BatchNetAmt > < SubItemList > < SubItemInf >0113|C1010211000012|00|CNY0.00|0|CNY400.00|4|</ SubItemInf > </ SubItemList > </ BatchInf > < BatchInf > < BatchId >B201805240006</ BatchId > < BatchDCFlg >2</ BatchDCFlg > < BatchNetAmt >CNY400.00</ BatchNetAmt > < SubItemList > < SubItemInf >0114|C1010211000012|00|CNY0.00|0|CNY400.00|4|</ SubItemInf > </ SubItemList > </ BatchInf > < BatchInf > < BatchId >B201805240007</ BatchId > < BatchDCFlg >2</ BatchDCFlg > < BatchNetAmt >CNY200.00</ BatchNetAmt > < SubItemList > < SubItemInf >0115|C1010211000012|01|CNY0.00|0|CNY200.00|2|</ SubItemInf > </ SubItemList > </ BatchInf > < BatchInf > < BatchId >B201805240008</ BatchId > < BatchDCFlg >2</ BatchDCFlg > < BatchNetAmt >CNY600.00</ BatchNetAmt > < SubItemList > < SubItemInf >0115|C1010211000012|01|CNY0.00|0|CNY600.00|2|</ SubItemInf > </ SubItemList > </ BatchInf > < BatchInf > < BatchId >B201805240009</ BatchId > < BatchDCFlg >2</ BatchDCFlg > < BatchNetAmt >CNY400.00</ BatchNetAmt > < SubItemList > < SubItemInf >0110|C1010511003703|00|CNY0.00|0|CNY400.00|2|</ SubItemInf > </ SubItemList > </ BatchInf > < BatchInf > < BatchId >B201805240010</ BatchId > < BatchDCFlg >2</ BatchDCFlg > < BatchNetAmt >CNY1200.00</ BatchNetAmt > < SubItemList > < SubItemInf >0111|C1010211000012|01|CNY0.00|0|CNY1200.00|4|</ SubItemInf > </ SubItemList > </ BatchInf > < BatchInf > < BatchId >B201805240012</ BatchId > < BatchDCFlg >1</ BatchDCFlg > < BatchNetAmt >CNY1200.00</ BatchNetAmt > < SubItemList > < SubItemInf >0116|C1010511003703|00|CNY1200.00|4|CNY0.00|0|</ SubItemInf > </ SubItemList > </ BatchInf > </ BatchList > </ SttlInf > </ SttlList > </ Root > |
主要核心代码如下
-
String saveFile
为本地保存xml报文的路径。 -
AccountInfoEntityResp
为解析xml后封装的obj实体对象。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
/** * 解析xml文件并 */ public String Dom4jGetXML(String saveFile){ //返回的Entity对象 String xmlContents = new String(); // 创建SAXReader的对象reader SAXReader reader = new SAXReader(); try { // Resource resource = new ClassPathResource("accountInfo/"+accountDate+".xml"); Resource resource = new ClassPathResource(saveFile); File file = null ; try { file = resource.getFile(); } catch (Exception e){ //抛出异常 } // 通过reader对象的read方法加载books.xml文件,获取docuemnt对象。 Document document = reader.read(file); // 通过document对象获取根节点bookstore Element rootElement = document.getRootElement(); //document转换为String字符串 xmlContents = document.asXML(); //解析xml文件并转换为obj } catch (DocumentException e) { // TODO Auto-generated catch block e.printStackTrace(); } return xmlContents; } |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
|
/** * 解析对账文件xml,转换为obj对象返回前段 * @Descriptions: 循环遍历所有子节点,保存每个节点的值 * @Return: AccountInfoEntity */ public AccountInfoEntityResp getNodes(Element node){ AccountInfoEntityResp accountInfoEntityResp = new AccountInfoEntityResp(); List<SttlInf> SttlList = new ArrayList<SttlInf>(); //获得指定节点下面的子节点,首先要知道自己要操作的节点。 Element SttlCntNbElem = node.element( "SttlCntNb" ); //获取SttlCntNb String SttlCntNb = SttlCntNbElem.getTextTrim(); //获取DebitCntAmt Element DebitCntAmtElem = node.element( "DebitCntAmt" ); String DebitCntAmt = DebitCntAmtElem.getTextTrim(); //获取CreditCntAmt Element CreditCntAmtElem = node.element( "CreditCntAmt" ); String CreditCntAmt = CreditCntAmtElem.getTextTrim(); accountInfoEntityResp.setSttlCntNb(Integer.valueOf(SttlCntNb)); BigDecimal CreditCntAmtVal = null ; if (CreditCntAmt != null && !CreditCntAmt.isEmpty()){ CreditCntAmtVal = new BigDecimal(CreditCntAmt.replace( "CNY" , "" )); } accountInfoEntityResp.setCreditCntAmt(CreditCntAmtVal); BigDecimal DebitCntAmtval = null ; if (DebitCntAmt != null && !DebitCntAmt.isEmpty()){ DebitCntAmtval = new BigDecimal(DebitCntAmt.replace( "CNY" , "" )); } accountInfoEntityResp.setDebitCntAmt(DebitCntAmtval); //获取SttlList Element SttlListEle = node.element( "SttlList" ); //获取SttlInf Element SttlInfEle = SttlListEle.element( "SttlInf" ); List<Element> SttlInfList = SttlListEle.elements(); //遍历SttlInfList节点 String SttlReptFlg = "" ; Integer SttlDCFlg = null ; BigDecimal SttlAmt = null ; for (Element e : SttlInfList){ List<BatchInf> BatchList = new ArrayList<BatchInf>(); SttlInf sttlInf = new SttlInf(); //SttlInf下的子节点 Element SttlReptFlgEle = e.element( "SttlReptFlg" ); SttlReptFlg = SttlReptFlgEle.getTextTrim(); Element SttlDCFlgEle = e.element( "SttlDCFlg" ); SttlDCFlg = Integer.valueOf(SttlDCFlgEle.getTextTrim()); Element SttlAmtEle = e.element( "SttlAmt" ); SttlAmt = new BigDecimal(SttlAmtEle.getTextTrim().replace( "CNY" , "" )); //设值 sttlInf.setSttlAmt(SttlAmt); sttlInf.setSttlDCFlg(SttlDCFlg); sttlInf.setSttlReptFlg(SttlReptFlg); //获取BatchList节点 Element BatchListEle = e.element( "BatchList" ); //获取BatchInf List<Element> BatchInfList = BatchListEle.elements(); for (Element e2 : BatchInfList){ List<SubItemInf> SubItemList = new ArrayList<SubItemInf>(); BatchInf batchInf = new BatchInf(); String BatchId = "" ; Integer BatchDCFlg = null ; BigDecimal BatchNetAmt = null ; Element BatchIdEle = e2.element( "BatchId" ); BatchId = BatchIdEle.getTextTrim(); Element BatchDCFlgEle = e2.element( "BatchDCFlg" ); BatchDCFlg = Integer.valueOf(BatchDCFlgEle.getTextTrim()); Element BatchNetAmtEle = e2.element( "BatchNetAmt" ); BatchNetAmt = new BigDecimal(BatchNetAmtEle.getTextTrim().replace( "CNY" , "" )); batchInf.setBatchDCFlg(BatchDCFlg); batchInf.setBatchId(BatchId); batchInf.setBatchNetAmt(BatchNetAmt); //获取SubItemList节点 Element SubItemListEle = e2.element( "SubItemList" ); //获取BatchInf List<Element> SubItemInfList = SubItemListEle.elements(); for (Element e3 : SubItemInfList){ SubItemInf subItemInf = new SubItemInf(); String subItem = "" ; subItem = e3.getTextTrim().replace( "CNY" , "" ); subItemInf.setSubItemInf(subItem); SubItemList.add(subItemInf); } batchInf.setSubItemList(SubItemList); BatchList.add(batchInf); } sttlInf.setBatchList(BatchList); SttlList.add(sttlInf); } accountInfoEntityResp.setSttlList(SttlList); return accountInfoEntityResp; } |
dom4j解析多层xml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
package com.bessky.hrmis.test; import java.util.Iterator; import org.dom4j.Document; import org.dom4j.DocumentHelper; import org.dom4j.Element; import org.dom4j.io.SAXReader; public class Dom4JDemo { public static void main(String[] args) throws Exception { // 1.创建Reader对象 SAXReader reader = new SAXReader(); String str = "<cas:serviceResponse xmlns:cas='http://www.yale.edu/tp/cas'>\r\n" + " <cas:authenticationSuccess>\r\n" + " <cas:user>hanke_tom</cas:user>\r\n" + " <cas:attributes>\r\n" + " <cas:credentialType>tom</cas:credentialType>\r\n" + " <cas:logout_url>http://192.168.1.5:8080/sso/logout</cas:logout_url>\r\n" + " <cas:isFromNewLogin>false</cas:isFromNewLogin>\r\n" + " <cas:authenticationDate>2019-11-26T17:47:55.789+08:00[Asia/Shanghai]</cas:authenticationDate>\r\n" + " <cas:user_id>01</cas:user_id>\r\n" + " <cas:authenticationMethod>TomAuthenticationHandler</cas:authenticationMethod>\r\n" + " <cas:successfulAuthenticationHandlers>TomAuthenticationHandler</cas:successfulAuthenticationHandlers>\r\n" + " <cas:name>张三</cas:name>\r\n" + " <cas:longTermAuthenticationRequestTokenUsed>false</cas:longTermAuthenticationRequestTokenUsed>\r\n" + " <cas:job_number>00001</cas:job_number>\r\n" + " <cas:username>hanke_tom</cas:username>\r\n" + " </cas:attributes>\r\n" + " </cas:authenticationSuccess>\r\n" + "</cas:serviceResponse>" ; // 2.加载xml Document document = DocumentHelper.parseText(str); // 3.获取根节点 Element rootElement = document.getRootElement(); Iterator iterator = rootElement.elementIterator(); System.out.println( "根节点:" + rootElement.getName()); // 拿到根节点的名称 Iterator bbbb = rootElement.elementIterator( "authenticationSuccess" ); while (bbbb.hasNext()) { Element recordEless = (Element) bbbb.next(); Iterator cccc = recordEless.elementIterator( "attributes" ); while (cccc.hasNext()) { Element itemEle = (Element) cccc.next(); String username = itemEle.elementTextTrim( "job_number" ); System.err.println( "---------" +username); } } } } |
如果后面还有子级继续while向下取数据
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/xuri24/article/details/83113340