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. }

运行之后的结果会是:

根节点:html
title:dom4j解析一个例子
username:yangrong
password:123456
result:0
banlce:1000
subID:36242519880716
result=0
username=yangrong
title=dom4j解析一个例子
subID=36242519880716
banlce=1000
password=123456
137000000===ff8080813349da9001334f0eed8c5923
187000000===ff8080813349da9001334f0eee045924

 转自http://blog.chinaunix.net/uid-25728370-id-2983116.html

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

  1. java解析xml字符串为实体(dom4j解析)

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

  2. java解析xml字符串方法

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

  3. 最简单的JAVA解析XML字符串方法

    引入 dom4j 包<dependency> <groupId>dom4j</groupId> <artifactId>dom4j</artifa ...

  4. Java解析XML字符串,取出其中<aaaa><![CDATA[(XXX)]]></aaa>里面的XXX值,也可以使用xml解析的其他方式,这是最简单的字符串解析

    直接贴一段业务代码,这段代码是解析请求返回的xml格式字符串,为了取出其中的值便于下一步的使用. @RequestMapping(value="/search",produces ...

  5. XML概念定义以及如何定义xml文件编写约束条件java解析xml DTD XML Schema JAXP java xml解析 dom4j 解析 xpath dom sax

    本文主要涉及:xml概念描述,xml的约束文件,dtd,xsd文件的定义使用,如何在xml中引用xsd文件,如何使用java解析xml,解析xml方式dom sax,dom4j解析xml文件 XML来 ...

  6. dom4j解析xml字符串实例

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

  7. 使用Java解析XML文件或XML字符串的例子

    转: 使用Java解析XML文件或XML字符串的例子 2017年09月16日 11:36:18 inter_peng 阅读数:4561 标签: JavaXML-Parserdom4j 更多 个人分类: ...

  8. Java解析XML汇总(DOM/SAX/JDOM/DOM4j/XPath)

    [目录] 一.[基础知识——扫盲] 二.[DOM.SAX.JDOM.DOM4j简单使用介绍] 三.[性能测试] 四.[对比] 五.[小插曲XPath] 六.[补充] 关键字:Java解析xml.解析x ...

  9. Java解析XML之Dom4j

    Java解析XML文件的方法有多种,个人感觉最常用的是使用Dom4j来解析XML文件.下面就简单介绍下Dom4j的基础使用. Dom4j需要jar包的支持,大家可以从网络上下载,如dom4j-1.6. ...

随机推荐

  1. 趣味SQL——创建指定的数据类型

    原创作品,出自 "深蓝的blog" 博客,深蓝的blog:http://blog.csdn.net/huangyanlong/article/details/46908843 趣味 ...

  2. mysql lower_case_table_names ---- 一律把表名处理为小写

    一.从操作系统说起: 1.我们知道mysql 是跨平台的.它可以在许多平台上运行如windows .linux.unix(mac).linux 是类unix的, 但是windows和linux就有非常 ...

  3. unity, imageEffect的最后一步blit所用的shader,应该关闭zwrite和ztest

    给项目组做了个imageEffect特效,结果导致ngui不显示(ugui则不存在此问题),看ngui的一些shader,其中ztest是开着的,而且ui相机的Clear Flags用的是Don't ...

  4. Android学习笔记(八)——显示运行进度对话框

    显示运行进度对话框 我们经常有这种经历:运行某一应用程序时.须要等待一会,这时会显示一个进度(Please Wait)对话框,让用户知道操作正在进行. 我们继续在上一篇中的程序中加入代码~ 1.在上一 ...

  5. linux(二十一):apache服务配置(二)

    1.普通用户进入家文件夹 ​ ​紧接着之前的进度,我们想想博客的实现.每一个用户在登录之后.都是在自己的家文件夹.那么对于我们的要求就是要设置每一个用户的默认公布文件夹为其家文件夹. 接着我们就来实现 ...

  6. 算法5-6:Kd树

    问题 给定一系列的点.和一个矩形.求矩形中包括的点的数量. 解答 这个问题能够通过建立矩阵来进行求解.首先将一个空间切割成矩阵,将点放置在相应的格子中.再计算矩形覆盖的格子.再推断格子中的点是否包括在 ...

  7. 二叉排序树及其C代码

    1.二叉排序树的定义   二叉排序树(Binary Sort Tree)又称二叉查找(搜索)树(Binary Search Tree).其定义为:二叉排序树或者是空树, 或者是满足例如以下性质的二叉树 ...

  8. ny33 蛇形填数

    蛇形填数 时间限制:3000 ms  |  内存限制:65535 KB 难度:3 描述 在n*n方陈里填入1,2,...,n*n,要求填成蛇形.例如n=4时方陈为: 10 11 12 1 9 16 1 ...

  9. JS中同步与异步的理解

    你应该知道,javascript语言是一门“单线程”的语言,不像java语言,类继承Thread再来个thread.start就可以开辟一个线程,所以,javascript就像一条流水线,仅仅是一条流 ...

  10. 获取Oracle数据库中字段信息

    select t.DATA_PRECISION,t.DATA_SCALE,t.DATA_LENGTH,t.DATA_TYPE,t.COLUMN_NAME, t.NULLABLE,t.DATA_DEFA ...