1. package com.smsServer.Dhst;
  2. import java.util.HashMap;
  3. import java.util.Iterator;
  4. import java.util.Map;
  5. import org.dom4j.Document;
  6. import org.dom4j.DocumentException;
  7. import org.dom4j.DocumentHelper;
  8. import org.dom4j.Element;
  9. import com.common.object.SmsSendResponseObject;
  10. /**
  11. * @description 解析xml字符串
  12. */
  13. public class Test {
  14. public void readStringXml(String xml) {
  15. Document doc = null;
  16. try {
  17. // 读取并解析XML文档
  18. // SAXReader就是一个管道,用一个流的方式,把xml文件读出来
  19. // SAXReader reader = new SAXReader(); //User.hbm.xml表示你要解析的xml文档
  20. // Document document = reader.read(new File("User.hbm.xml"));
  21. // 下面的是通过解析xml字符串的
  22. doc = DocumentHelper.parseText(xml); // 将字符串转为XML
  23. Element rootElt = doc.getRootElement(); // 获取根节点
  24. System.out.println("根节点:" + rootElt.getName()); // 拿到根节点的名称
  25. Iterator iter = rootElt.elementIterator("head"); // 获取根节点下的子节点head
  26. // 遍历head节点
  27. while (iter.hasNext()) {
  28. Element recordEle = (Element) iter.next();
  29. String title = recordEle.elementTextTrim("title"); // 拿到head节点下的子节点title值
  30. System.out.println("title:" + title);
  31. Iterator iters = recordEle.elementIterator("script"); // 获取子节点head下的子节点script
  32. // 遍历Header节点下的Response节点
  33. while (iters.hasNext()) {
  34. Element itemEle = (Element) iters.next();
  35. String username = itemEle.elementTextTrim("username"); // 拿到head下的子节点script下的字节点username的值
  36. String password = itemEle.elementTextTrim("password");
  37. System.out.println("username:" + username);
  38. System.out.println("password:" + password);
  39. }
  40. }
  41. Iterator iterss = rootElt.elementIterator("body"); ///获取根节点下的子节点body
  42. // 遍历body节点
  43. while (iterss.hasNext()) {
  44. Element recordEless = (Element) iterss.next();
  45. String result = recordEless.elementTextTrim("result"); // 拿到body节点下的子节点result值
  46. System.out.println("result:" + result);
  47. Iterator itersElIterator = recordEless.elementIterator("form"); // 获取子节点body下的子节点form
  48. // 遍历Header节点下的Response节点
  49. while (itersElIterator.hasNext()) {
  50. Element itemEle = (Element) itersElIterator.next();
  51. String banlce = itemEle.elementTextTrim("banlce"); // 拿到body下的子节点form下的字节点banlce的值
  52. String subID = itemEle.elementTextTrim("subID");
  53. System.out.println("banlce:" + banlce);
  54. System.out.println("subID:" + subID);
  55. }
  56. }
  57. } catch (DocumentException e) {
  58. e.printStackTrace();
  59. } catch (Exception e) {
  60. e.printStackTrace();
  61. }
  62. }
  63. /**
  64. * @description 将xml字符串转换成map
  65. * @param xml
  66. * @return Map
  67. */
  68. public static Map readStringXmlOut(String xml) {
  69. Map map = new HashMap();
  70. Document doc = null;
  71. try {
  72. doc = DocumentHelper.parseText(xml); // 将字符串转为XML
  73. Element rootElt = doc.getRootElement(); // 获取根节点
  74. System.out.println("根节点:" + rootElt.getName()); // 拿到根节点的名称
  75. Iterator iter = rootElt.elementIterator("head"); // 获取根节点下的子节点head
  76. // 遍历head节点
  77. while (iter.hasNext()) {
  78. Element recordEle = (Element) iter.next();
  79. String title = recordEle.elementTextTrim("title"); // 拿到head节点下的子节点title值
  80. System.out.println("title:" + title);
  81. map.put("title", title);
  82. Iterator iters = recordEle.elementIterator("script"); // 获取子节点head下的子节点script
  83. // 遍历Header节点下的Response节点
  84. while (iters.hasNext()) {
  85. Element itemEle = (Element) iters.next();
  86. String username = itemEle.elementTextTrim("username"); // 拿到head下的子节点script下的字节点username的值
  87. String password = itemEle.elementTextTrim("password");
  88. System.out.println("username:" + username);
  89. System.out.println("password:" + password);
  90. map.put("username", username);
  91. map.put("password", password);
  92. }
  93. }
  94. Iterator iterss = rootElt.elementIterator("body"); ///获取根节点下的子节点body
  95. // 遍历body节点
  96. while (iterss.hasNext()) {
  97. Element recordEless = (Element) iterss.next();
  98. String result = recordEless.elementTextTrim("result"); // 拿到body节点下的子节点result值
  99. System.out.println("result:" + result);
  100. Iterator itersElIterator = recordEless.elementIterator("form"); // 获取子节点body下的子节点form
  101. // 遍历Header节点下的Response节点
  102. while (itersElIterator.hasNext()) {
  103. Element itemEle = (Element) itersElIterator.next();
  104. String banlce = itemEle.elementTextTrim("banlce"); // 拿到body下的子节点form下的字节点banlce的值
  105. String subID = itemEle.elementTextTrim("subID");
  106. System.out.println("banlce:" + banlce);
  107. System.out.println("subID:" + subID);
  108. map.put("result", result);
  109. map.put("banlce", banlce);
  110. map.put("subID", subID);
  111. }
  112. }
  113. } catch (DocumentException e) {
  114. e.printStackTrace();
  115. } catch (Exception e) {
  116. e.printStackTrace();
  117. }
  118. return map;
  119. }
  120. public static void parse(String xml)
  121. {
  122. Document doc = null;
  123. try {
  124. doc = DocumentHelper.parseText(xml); // 将字符串转为XML
  125. Element rootElt = doc.getRootElement(); // 获取根节点smsReport
  126. Iterator iters = rootElt.elementIterator("sendResp"); // 获取根节点下的子节点sms
  127. while (iters.hasNext()) {
  128. Element recordEle1 = (Element) iters.next();
  129. Iterator iter = recordEle1.elementIterator("sms");
  130. int i=0;
  131. // 遍历sms节点
  132. while (iter.hasNext()) {
  133. Element recordEle = (Element) iter.next();
  134. SmsSendResponseObject r = new SmsSendResponseObject();
  135. String phone = recordEle.elementTextTrim("phone"); // 拿到sms节点下的子节点stat值
  136. String smsID = recordEle.elementTextTrim("smsID"); // 拿到sms节点下的子节点stat值
  137. System.out.println(phone+"==="+smsID);
  138. }
  139. }
  140. } catch (DocumentException e) {
  141. e.printStackTrace();
  142. } catch (Exception e) {
  143. e.printStackTrace();
  144. }
  145. }
  146. public static void main(String[] args) {
  147. // 下面是需要解析的xml字符串例子
  148. String xmlString = "" + "" + ""
  149. + "" + ""
  150. + "" + "0" + ""
  151. + "1000" + "36242519880716"
  152. + "" + " " + "";
  153. /*
  154. * Test2 test = new Test2(); test.readStringXml(xmlString);
  155. */
  156. Map map = readStringXmlOut(xmlString);
  157. Iterator iters = map.keySet().iterator();
  158. while (iters.hasNext()) {
  159. String key = iters.next().toString(); // 拿到键
  160. String val = map.get(key).toString(); // 拿到值
  161. System.out.println(key + "=" + val);
  162. }
  163. String xml="137000000ff8080813349da9001334f0eed8c5923187000000ff8080813349da9001334f0eee045924";
  164. parse(xml);
  165. }
  166. }

java解析xml字符串为实体(dom4j解析)的更多相关文章

  1. java解析xml字符串(用dom4j)

    package com.smsServer.Dhst; import java.util.HashMap; import java.util.Iterator; import java.util.Ma ...

  2. 源生API解析XML文档与dom4j解析XML文档

    一.XML语言 XML是一种可扩展的标记语言,是一种强类型的语言,类似HTML(超文本标记语言,是一种弱类型的语言).XML是一种通用的数据交换格式(关系型数据库),综上所诉:XML可以传输数据,也可 ...

  3. .NET解析xml字符串,通过反射给实体类对象赋值,获取实体类数据列表

    /// <summary> /// 解析xml字符串 转换为实体类列表数据 /// </summary> /// <param name="xmlStr&quo ...

  4. java解析xml字符串方法

    一,用DOM4J  针对无重复标签的xml字符串格式,如下: 针对此种情况可用DOM4J解析法,引入 dom4j的相关jar包代码如下: Document document=DocumentHelpe ...

  5. dom4j解析xml字符串实例

    DOM4J 与利用DOM.SAX.JAXP机制来解析xml相比,DOM4J 表现更优秀,具有性能优异.功能强大和极端易用使用的特点,只要懂得DOM基本概念,就可以通过dom4j的api文档来解析xml ...

  6. 解析xml字符串时报“前言中不允许有内容”错误。

    一,问题出现经过: j基于java语言webservic服务端接收客户端 传来的xml字符串用 解析时总报:org.dom4j.DocumentException: Error on line 1 o ...

  7. tinyXml直接解析XML字符串

    一直都用tinyxml直接LoadFile来解析XML,发现原来也可以直接解析XML字符串. XML文件: <?xml version=\"1.0\" encoding=\& ...

  8. C++解析XML字符串

    项目交互遇到了需要VC++中解析XML字符串,故花了点时间了解了下VC++中解析XML的诸多方法主要包括三种:msxml(微软提供).markup.TinyXml. 开始花了点时间使用msxml3,虽 ...

  9. dom4j递归解析XML字符串所有子节点

    /** * dom4j递归解析所有子节点 * * @param childElements * @param mapEle * @return */ public Map<String, Obj ...

随机推荐

  1. Node.js abaike图片批量下载Node.js爬虫1.00版

    这个与前作的差别在于地址的不规律性,需要找到下一页的地址再爬过去找. //====================================================== // abaik ...

  2. 模板:什么是Traits

    Traits不是一种语法特性,而是一种模板编程技巧.Traits在C++标准库,尤其是STL中,有着不可替代的作用.   如何在编译期间区分类型   下面我们看一个实例,有四个类,Farm.Worke ...

  3. HDU 1560 IDA*搜索

    用N个串中找到最短的公共串(不要求连续,仅仅要相对位置一样就可以) 迭代加深搜索就可以 剪枝:当前的深度+最少还有加深的深度是否大于限制的长度,若是,则退回. #include "stdio ...

  4. 查看tomcat启动文件都干点啥---catalina.bat

    在上一次查看tomcat启动文件都干点啥一文中,我们总结出,startup.bat文件的作用就是找到catalina.bat文件,然后把参数传递给它,在startup.bat中,调用catalina. ...

  5. 语言那点事,crt

    C语言标准(不管是ANSI 还是ISO)包含2部分,一部分是语言本身的标准,另一部分是C标准函数库.C标准函数库规定了函数的原型和功能,但是并没限定这些函数要怎么实现.所谓满足标准C规定的C编译器,不 ...

  6. nginx和Tomcat集成后发生的重定向问题分析和解决

    nginx和Tomcat集成后发生的重定向问题分析和解决 Tomcat前端配置一个HTTP服务器应该是大部分应用的标配了,基本思路就是所有动态请求都反向代理给后端的Tomcat,HTTP服务器来处 理 ...

  7. java filter、listener、servlet

    listener http://www.cnblogs.com/xdp-gacl/p/3969249.html http://blog.csdn.net/java_pengjin/article/de ...

  8. 【web开发学习笔记】Structs2 Result学习笔记(一)简介

    Structs2 Result学习笔记(一)简介 问题一 <struts> <constant name="struts.devMode" value=" ...

  9. 深入研究mysql中group by与order by取分类最新时间内容

    鉴于项目的需要,就从网上找到该文章,文章分析得很详细也很易懂,在android里,(不知道是不是现在水平的限制,总之我还没找到在用 ContentProvider时可以使用子查询),主要方法是用SQL ...

  10. sublime test3 安装及配置

    操作系统: Ubuntu16.04 注: 除下载及安装外,其他配置不限操作系统 1. 下载及安装 官网:https://www.sublimetext.com/ 进入官网 点击 INSTALL FOR ...