Dom4j解析xml复杂多节点报文方式

目录
  • Dom4j解析xml复杂多节点报文
    • XML的解析方式分为四种
    • 本文介绍的是DOM4J方式解析
    • 主要核心代码如下
  • dom4j解析多层xml

Dom4j解析xml复杂多节点报文

XML是一种通用的数据交换格式,它的平台无关性、语言无关性、系统无关性、给数据集成与交互带来了极大的方便。XML在不同的语言环境中解析方式都是一样的,只不过实现的语法不同而已。

XML的解析方式分为四种

1、DOM解析

2、SAX解析

3、JDOM解析

4、DOM4J解析

其中前两种属于基础方法,是官方提供的平台无关的解析方式;后两种属于扩展方法,它们是在基础的方法上扩展出来的,只适用于java平台。

本文介绍的是DOM4J方式解析

依赖jar包:

  <dependency>
   <groupId>dom4j</groupId>
   <artifactId>dom4j</artifactId>
   <version>1.6.1</version>
  </dependency>

xml报文如下:

<?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实体对象。
/**
     * 解析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;
    }
/**
     * 解析对账文件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

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向下取数据

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • java dom4j解析xml用到的几个方法

    1. 读取并解析XML文档: 复制代码 代码如下: SAXReader reader = new SAXReader(); Document document = reader.read(new File(fileName)); reader的read方法是重载的,可以从InputStream, File, Url等多种不同的源来读取.得到的Document对象就带表了整个XML. 读取的字符编码是按照XML文件头定义的编码来转换.如果遇到乱码问题,注意要把各处的编码名称保持一致即可. 2. 取

  • java中使用dom4j解析XML文件的方法教程

    前言 dom4j是一个java的XML api,性能优异.功能强大.易于使用.以前听说过来解析xml文件的几种标准方式:但是从来的没有应用过来,所以可以在google中搜索dmo4j解析xml文件的方式,学习一下dom4j解析xml的具体操作.下面话不多说了,来一起看看详细的介绍吧 官网下载Dom4j地址:https://dom4j.github.io/ 注意:使用Dom4j开发,需下载dom4j相应的jar文件 题目:后台利用dom4j解析student.xml文件,并返回List<Stude

  • 在java中使用dom4j解析xml(示例代码)

    虽然Java中已经有了Dom和Sax这两种标准解析方式 但其操作起来并不轻松,对于我这么一个初学者来说,其中部分代码是活生生的恶心 为此,伟大的第三方开发组开发出了Jdom和Dom4j等工具 鉴于目前的趋势,我们这里来讲讲Dom4j的基本用法,不涉及递归等复杂操作 Dom4j的用法很多,官网上的示例有那么点儿晦涩,这里就不写了 首先我们需要出创建一个xml文档,然后才能对其解析 xml文档: 复制代码 代码如下: <?xml version="1.0" encoding=&quo

  • Dom4j解析xml复杂多节点报文方式

    目录 Dom4j解析xml复杂多节点报文 XML的解析方式分为四种 本文介绍的是DOM4J方式解析 主要核心代码如下 dom4j解析多层xml Dom4j解析xml复杂多节点报文 XML是一种通用的数据交换格式,它的平台无关性.语言无关性.系统无关性.给数据集成与交互带来了极大的方便.XML在不同的语言环境中解析方式都是一样的,只不过实现的语法不同而已. XML的解析方式分为四种 1.DOM解析 2.SAX解析 3.JDOM解析 4.DOM4J解析 其中前两种属于基础方法,是官方提供的平台无关的

  • Java 解析XML数据的4种方式

    解析的四种方式 DOM 解析 SAX 解析 JDOM 解析 DOM4J 解析 案例实操 DOM 解析 DOM(Document Object Model, 文档对象模型),在应用程序中,基于 DOM 的 XML 分析器将一个 XML 文档转换成一个对象模型的集合(通常称为 DOM 树 ),应用程序正是通过对这个对象模型的操作,来实现对 XML 文档数据的操作.XML 本身是以树状的形式出现的,所以 DOM 操作的时候,也将按章树的形式进行转换.在整个 DOM 树中,最大的地方指的是 Docume

  • java dom4j解析xml文件代码实例分享

    解析xml文件有两种方式,一种是利用Dom去解析,这种方式写起代码比较麻烦,对于刚入手的程序员来说比较容易出问题:第二种就是使用Dom4j包去解析在要使用Dom4j包的时候,肯定要先引入包 复制代码 代码如下: import java.io.File;import java.io.FileWriter;import java.io.IOException;import java.io.Writer;import java.util.Iterator; import org.dom4j.Docum

  • java使用xpath和dom4j解析xml

    1 XML文件解析的4种方法 通常解析XML文件有四种经典的方法.基本的解析方式有两种,一种叫SAX,另一种叫DOM.SAX是基于事件流的解析,DOM是基于XML文档树结构的解析.在此基础上,为了减少DOM.SAX的编码量,出现了JDOM,其优点是,20-80原则(帕累托法则),极大减少了代码量.通常情况下JDOM使用时满足要实现的功能简单,如解析.创建等要求.但在底层,JDOM还是使用SAX(最常用).DOM.Xanan文档.另外一种是DOM4J,是一个非常非常优秀的Java XML API,

  • java解析xml常用的几种方式总结

    各种方法都用过.现在总结一下. 经常记不住,要找资料.现在总结一下. xml 文件如下: 复制代码 代码如下: <?xml version="1.0" encoding="ISO-8859-1"?><bookstore><book category="COOKING">  <title lang="en">Everyday Italian</title>  <a

  • 通过dom4j解析xml字符串(示例代码)

    复制代码 代码如下: import java.util.Iterator;import java.util.List;import org.dom4j.Attribute;import org.dom4j.Document;import org.dom4j.DocumentHelper;import org.dom4j.Element;public class Test { @SuppressWarnings("unchecked") public static void main(S

  • java解析xml之dom4j解析xml示例分享

    复制代码 代码如下: package com.test; import java.io.File;import java.util.ArrayList;import java.util.Iterator;import java.util.List; import org.dom4j.Document;import org.dom4j.Element;import org.dom4j.io.SAXReader; public class Dom4jXML { public static void

随机推荐