dom4j解析xml的简单实用
2017-04-27 00:00
477 查看
我们拿支付宝对账的订单来解析。
上面的截图是,支付宝对账结果的一部分数据。下面我写下具体的代码:
上面的截图是,支付宝对账结果的一部分数据。下面我写下具体的代码:
private Map<String, Object> xmlToMap(InputStream inputStream){ Map<String, Object> resultMap = new HashMap<String, Object>(); SAXReader reader = new SAXReader(); List<AccountQueryAccountLogVO> accountQueryAccountLogVOs = new ArrayList<AccountQueryAccountLogVO>(); try { org.dom4j.Document doc = reader.read(inputStream); //获取alipay节点以下的所有子节点 List<Node> nodeList = doc.selectNodes("//alipay/*"); for (Node node : nodeList) { String nodeName = node.getName(); //判断是否有成功标示 if ("is_success".equals(nodeName) && node.getText().equals("T")) { //解析响应的内容信息 List<Node> tempList = doc.selectNodes("//response/account_page_query_result/*"); if (tempList != null && tempList.size() > 0) { for (Node node1 : tempList) { String tempNodeName = node1.getName(); String tempNodeText = node1.getText(); if ("has_next_page".equals(tempNodeName)) { LOGGER.debug("是否有下一页:{}", "T".equals(tempNodeText) ? true : false); resultMap.put("has_next_page", "T".equals(tempNodeText) ? true : false); } if ("page_no".equals(tempNodeName)) { LOGGER.debug("当前页码:{}", tempNodeText); resultMap.put("page_no", tempNodeText); } if ("page_size".equals(tempNodeName)) { LOGGER.debug("每页显示条数:{}", tempNodeText); } if ("account_log_list".equals(tempNodeName)) { List<Node> accountLogs = node1.selectNodes("AccountQueryAccountLogVO"); for (Node accountLog : accountLogs) { AccountQueryAccountLogVO accountQueryAccountLogVO = new AccountQueryAccountLogVO(); //商户订单号 String merchant_out_order_no = accountLog.selectSingleNode("merchant_out_order_no").getText(); //支付宝交易号 String trade_no = accountLog.selectSingleNode("trade_no").getText(); //只匹配客户端充值的信息 if (pattern.matcher(trade_no).matches()) { //todo } if (StringUtils.isNoneBlank(merchant_out_order_no)) { accountQueryAccountLogVO.setMerchant_out_order_no(merchant_out_order_no); } if (StringUtils.isNotBlank(trade_no)) { accountQueryAccountLogVO.setTrade_no(trade_no); } accountQueryAccountLogVOs.add(accountQueryAccountLogVO); } resultMap.put("rows", accountQueryAccountLogVOs); } } } } } } catch (Exception e) { LOGGER.error("解析遇到bug{}", e.getMessage()); } LOGGER.debug("==============解析xml结束,共收集客户端账单条数:{}", accountQueryAccountLogVOs.size()); return resultMap; }
相关文章推荐
- dom4j解析XML简单方法
- 关于Dom4j解析XML文件,外带上一个简单工具
- Java之dom4j的简单解析和生成xml的应用
- Dom4j解析XML学习之简单解析
- 简单实现dom4j解析xml
- 简单用DOM4J结合XPATH解析XML
- 简单使用DOM4J解析XML(如何使用dom4j对xml进行读取)
- xml简单介绍及使用dom4j进行解析
- 简单xml的使用以及xml的解析dom4j和jaxp
- DOM4J解析xml最简单例子
- dom4j解析XML简单例子
- dom4j 对xml文件循环解析简单实例
- dom、SAX、Jdom、dom4j四种解析xml方式简单总结
- XPath 解析xml文档简单实用例子
- 在已知XML文件内容时,使用dom4j简单解析XML(String类型的XML)(用于服务器端)
- DOM4J学习笔记 --- Java简单解析XML数据
- Dom4j解析XML简单应用,XStream实现Java、XML转换
- dom4j解析xml简单列子
- 最简单的一个XML解析-dom4j
- DOM4J结合XPATH简单解析xml