Java 解析XML

XML

<?xml version='1.0' encoding='UTF-8'?>
<soapenv:Envelope xmlns:soapenv="http://xxx.xxx.org/xxx/xxx/">
    <soapenv:Body>
        <ns:getBasicPersonInfoResponse xmlns:ns="http://www.xxx.com/xsd">
            <ns:return>{"code":"1000","msg":"success","data":"&lt;ERROR&gt;0&lt;\/ERROR&gt;&lt;INFO&gt;&lt;\/INFO&gt;&lt;CARD&gt;&lt;社会保障卡卡号&gt;88888888&lt;\/社会保障卡卡号&gt;&lt;卡识别码&gt;6987415D156888885403E61D29D4EA5tg&lt;\/卡识别码&gt;&lt;卡片复位信息&gt;00dfdgdfdfdd9888888101C8149A&lt;\/卡片复位信息&gt;&lt;发卡日期&gt;20210506&lt;\/发卡日期&gt;&lt;卡有效期&gt;20310506&lt;\/卡有效期&gt;&lt;卡应用状态&gt;2&lt;\/卡应用状态&gt;&lt;开户银行行号&gt;8888888888888888&lt;\/开户银行行号&gt;&lt;银行卡卡号&gt;8888888888888888888&lt;\/银行卡卡号&gt;&lt;发卡地行政区划代码&gt;6987415&lt;\/发卡地行政区划代码&gt;&lt;卡面姓名&gt;张三三&lt;\/卡面姓名&gt;&lt;卡面社会保障号码&gt;888888888888888888&lt;\/卡面社会保障号码&gt;&lt;卡规范版本&gt;3.00&lt;\/卡规范版本&gt;&lt;\/CARD&gt;"}</ns:return>
        </ns:getBasicPersonInfoResponse>
    </soapenv:Body>
</soapenv:Envelope>

引入依赖
dom4j是一个Java的XML API,是jdom的升级品,用来读写XML文件的。

<dependency>
    <groupId>org.dom4j</groupId>
    <artifactId>dom4j</artifactId>
    <version>2.1.3</version>
</dependency>

解析代码

/**
* @param text xml文本
*/
private YlzResponse getYlzResponse(String text) throws Exception {
    Document doc = DocumentHelper.parseText(text);
    Element root = doc.getRootElement();
    Element body = root.element("Body");
    Element info = body.element("getBasicPersonInfoResponse");
    Element result = info.element("return");
    return Helper.fromJson(result.getText(), YlzResponse.class);
}

private LinkedHashMap<String, Object> toParas(Object pointId, Object text) throws Exception {
    String xml = String.format("<ROOT>%s</ROOT>", text);
    Document doc = DocumentHelper.parseText(xml);
    Element root = doc.getRootElement();
    Element card = root.element("CARD");

    LinkedHashMap<String, Object> map = new LinkedHashMap<>();
    map.put("pointId", pointId);
    map.put("userName", card.elementText("卡面姓名"));
    map.put("cardNumber", card.elementText("卡面社会保障号码"));
    return map;
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java 解析 XML 可以使用 DOM、SAX 和 StAX 等方式。其中,DOM 方式将整个 XML 文档加载到内存中,适合于小型 XML 文件;SAX 方式基于事件驱动,逐行读取 XML 文件,适合于大型 XML 文件;StAX 方式也是基于事件驱动,但可以在读取和写入之间切换,适合于大型 XML 文件的读写操作。 以下是使用 DOM 方式解析 XML 的示例代码: ```java import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.DocumentBuilder; import org.w3c.dom.Document;import org.w3c.dom.NodeList; import org.w3c.dom.Node; import org.w3c.dom.Element; import java.io.File; public class ReadXMLFile { public static void main(String argv[]) { try { File fXmlFile = new File("file.xml"); DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance(); DocumentBuilder dBuilder = dbFactory.newDocumentBuilder(); Document doc = dBuilder.parse(fXmlFile); doc.getDocumentElement().normalize(); System.out.println("Root element :" + doc.getDocumentElement().getNodeName()); NodeList nList = doc.getElementsByTagName("student"); System.out.println("----------------------------"); for (int temp = 0; temp < nList.getLength(); temp++) { Node nNode = nList.item(temp); System.out.println("\nCurrent Element :" + nNode.getNodeName()); if (nNode.getNodeType() == Node.ELEMENT_NODE) { Element eElement = (Element) nNode; System.out.println("Student roll no : " + eElement.getAttribute("rollno")); System.out.println("First Name : " + eElement.getElementsByTagName("firstname").item(0).getTextContent()); System.out.println("Last Name : " + eElement.getElementsByTagName("lastname").item(0).getTextContent()); System.out.println("Nick Name : " + eElement.getElementsByTagName("nickname").item(0).getTextContent()); System.out.println("Marks : " + eElement.getElementsByTagName("marks").item(0).getTextContent()); } } } catch (Exception e) { e.printStackTrace(); } } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值