- 浏览: 160523 次
- 性别:
- 来自: 西安
文章分类
最新评论
1.package com.smsServer.Dhst;
2.
3.import java.util.HashMap;
4.import java.util.Iterator;
5.import java.util.Map;
6.
7.import org.dom4j.Document;
8.import org.dom4j.DocumentException;
9.import org.dom4j.DocumentHelper;
10.import org.dom4j.Element;
11.
12.import com.common.object.SmsSendResponseObject;
13.
14./**
15. * @description 解析xml字符串
16. */
17.public class Test {
18.
19. public void readStringXml(String xml) {
20. Document doc = null;
21. try {
22.
23. // 读取并解析XML文档
24.
25. // SAXReader就是一个管道,用一个流的方式,把xml文件读出来
26.
27. // SAXReader reader = new SAXReader(); //User.hbm.xml表示你要解析的xml文档
28.
29. // Document document = reader.read(new File("User.hbm.xml"));
30.
31. // 下面的是通过解析xml字符串的
32.
33. doc = DocumentHelper.parseText(xml); // 将字符串转为XML
34.
35.
36. Element rootElt = doc.getRootElement(); // 获取根节点
37.
38. System.out.println("根节点:" + rootElt.getName()); // 拿到根节点的名称
39.
40.
41. Iterator iter = rootElt.elementIterator("head"); // 获取根节点下的子节点head
42.
43.
44. // 遍历head节点
45.
46. while (iter.hasNext()) {
47.
48. Element recordEle = (Element) iter.next();
49. String title = recordEle.elementTextTrim("title"); // 拿到head节点下的子节点title值
50.
51. System.out.println("title:" + title);
52.
53. Iterator iters = recordEle.elementIterator("script"); // 获取子节点head下的子节点script
54.
55.
56. // 遍历Header节点下的Response节点
57.
58. while (iters.hasNext()) {
59.
60. Element itemEle = (Element) iters.next();
61.
62. String username = itemEle.elementTextTrim("username"); // 拿到head下的子节点script下的字节点username的值
63.
64. String password = itemEle.elementTextTrim("password");
65.
66. System.out.println("username:" + username);
67. System.out.println("password:" + password);
68. }
69. }
70. Iterator iterss = rootElt.elementIterator("body"); ///获取根节点下的子节点body
71.
72. // 遍历body节点
73.
74. while (iterss.hasNext()) {
75.
76. Element recordEless = (Element) iterss.next();
77. String result = recordEless.elementTextTrim("result"); // 拿到body节点下的子节点result值
78.
79. System.out.println("result:" + result);
80.
81. Iterator itersElIterator = recordEless.elementIterator("form"); // 获取子节点body下的子节点form
82.
83. // 遍历Header节点下的Response节点
84.
85. while (itersElIterator.hasNext()) {
86.
87. Element itemEle = (Element) itersElIterator.next();
88.
89. String banlce = itemEle.elementTextTrim("banlce"); // 拿到body下的子节点form下的字节点banlce的值
90.
91. String subID = itemEle.elementTextTrim("subID");
92.
93. System.out.println("banlce:" + banlce);
94. System.out.println("subID:" + subID);
95. }
96. }
97. } catch (DocumentException e) {
98. e.printStackTrace();
99.
100. } catch (Exception e) {
101. e.printStackTrace();
102.
103. }
104. }
105.
106. /**
107. * @description 将xml字符串转换成map
108. * @param xml
109. * @return Map
110. */
111. public static Map readStringXmlOut(String xml) {
112. Map map = new HashMap();
113. Document doc = null;
114. try {
115. doc = DocumentHelper.parseText(xml); // 将字符串转为XML
116.
117. Element rootElt = doc.getRootElement(); // 获取根节点
118.
119. System.out.println("根节点:" + rootElt.getName()); // 拿到根节点的名称
120.
121.
122. Iterator iter = rootElt.elementIterator("head"); // 获取根节点下的子节点head
123.
124. // 遍历head节点
125.
126. while (iter.hasNext()) {
127.
128. Element recordEle = (Element) iter.next();
129. String title = recordEle.elementTextTrim("title"); // 拿到head节点下的子节点title值
130.
131. System.out.println("title:" + title);
132. map.put("title", title);
133.
134. Iterator iters = recordEle.elementIterator("script"); // 获取子节点head下的子节点script
135.
136.
137. // 遍历Header节点下的Response节点
138.
139. while (iters.hasNext()) {
140.
141. Element itemEle = (Element) iters.next();
142.
143. String username = itemEle.elementTextTrim("username"); // 拿到head下的子节点script下的字节点username的值
144.
145. String password = itemEle.elementTextTrim("password");
146.
147. System.out.println("username:" + username);
148. System.out.println("password:" + password);
149. map.put("username", username);
150. map.put("password", password);
151.
152. }
153. }
154.
155. Iterator iterss = rootElt.elementIterator("body"); ///获取根节点下的子节点body
156.
157. // 遍历body节点
158.
159. while (iterss.hasNext()) {
160. Element recordEless = (Element) iterss.next();
161. String result = recordEless.elementTextTrim("result"); // 拿到body节点下的子节点result值
162.
163. System.out.println("result:" + result);
164.
165. Iterator itersElIterator = recordEless.elementIterator("form"); // 获取子节点body下的子节点form
166.
167. // 遍历Header节点下的Response节点
168.
169. while (itersElIterator.hasNext()) {
170.
171. Element itemEle = (Element) itersElIterator.next();
172.
173. String banlce = itemEle.elementTextTrim("banlce"); // 拿到body下的子节点form下的字节点banlce的值
174.
175. String subID = itemEle.elementTextTrim("subID");
176.
177. System.out.println("banlce:" + banlce);
178. System.out.println("subID:" + subID);
179. map.put("result", result);
180. map.put("banlce", banlce);
181. map.put("subID", subID);
182. }
183. }
184. } catch (DocumentException e) {
185. e.printStackTrace();
186. } catch (Exception e) {
187. e.printStackTrace();
188. }
189. return map;
190. }
191. public static void parse(String xml)
192. {
193. Document doc = null;
194. try {
195. doc = DocumentHelper.parseText(xml); // 将字符串转为XML
196.
197. Element rootElt = doc.getRootElement(); // 获取根节点smsReport
198.
199. Iterator iters = rootElt.elementIterator("sendResp"); // 获取根节点下的子节点sms
200.
201. while (iters.hasNext()) {
202. Element recordEle1 = (Element) iters.next();
203. Iterator iter = recordEle1.elementIterator("sms");
204. int i=0;
205. // 遍历sms节点
206.
207. while (iter.hasNext()) {
208. Element recordEle = (Element) iter.next();
209. SmsSendResponseObject r = new SmsSendResponseObject();
210. String phone = recordEle.elementTextTrim("phone"); // 拿到sms节点下的子节点stat值
211.
212. String smsID = recordEle.elementTextTrim("smsID"); // 拿到sms节点下的子节点stat值
213.
214. System.out.println(phone+"==="+smsID);
215. }
216. }
217. } catch (DocumentException e) {
218. e.printStackTrace();
219. } catch (Exception e) {
220. e.printStackTrace();
221. }
222. }
223. public static void main(String[] args) {
224.
225. // 下面是需要解析的xml字符串例子
226.
227. String xmlString = "<html>" + "<head>" + "<title>dom4j解析一个例子</title>"
228. + "<script>" + "<username>yangrong</username>"
229. + "<password>123456</password>" + "</script>" + "</head>"
230. + "<body>" + "<result>0</result>" + "<form>"
231. + "<banlce>1000</banlce>" + "<subID>36242519880716</subID>"
232. + "</form>" + "</body>" + "</html>";
233.
234. /*
235. * Test2 test = new Test2(); test.readStringXml(xmlString);
236. */
237. Map map = readStringXmlOut(xmlString);
238. Iterator iters = map.keySet().iterator();
239. while (iters.hasNext()) {
240. String key = iters.next().toString(); // 拿到键
241.
242. String val = map.get(key).toString(); // 拿到值
243.
244. System.out.println(key + "=" + val);
245. }
246. String xml="<batchSendResp><sendResp><sms><phone>137000000</phone><smsID>ff8080813349da9001334f0eed8c5923</smsID></sms></sendResp><sendResp><sms><phone>187000000</phone><smsID>ff8080813349da9001334f0eee045924</smsID></sms></sendResp></batchSendResp>";
247. parse(xml);
248. }
249.
250.}
运行之后的结果会是:
根节点: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
发表评论
-
回调hanshu
2018-10-15 23:09 0java callback -
根据类名查找jar包路径
2018-08-12 01:04 913ProtectionDomain pd = StringUt ... -
https
2018-04-20 23:14 01:导出证书用IE的证书工具可以将网站的证书导出。打开网 ... -
mock request
2017-08-20 02:56 0一:postprotected ApplicationCont ... -
使用mockMvc测试文件上传
2017-08-20 01:52 6356@Autowired BanksController bank ... -
java 线程池实现多并发队列后进先出
2017-02-15 00:33 1842java实现线程池多并发队列后进先出 目前默认的队列都是先 ... -
apache ftp server
2017-01-11 22:41 614apache ftp server -
证书制作工具
2016-06-29 23:28 691证书制作工具 -
spring mvc 初始化加载bean
2016-06-15 20:28 1373<context:component-scan bas ... -
Ribbon 和 Eureka 的集成
2016-06-11 00:42 2875Ribbon 是 Netflix 发布的云中间层服务开源项目 ... -
RestTemplate实践
2016-06-11 00:30 941什么是RestTemplate? RestTemplat ... -
@Component(“”)和@resource(name=””)的使用:
2016-06-08 01:24 12252@Component(“”)和@resource(nam ... -
springboot ant部署
2016-06-08 01:03 966springboot ant部署 -
springboot 使用外部tomcat启动
2016-06-05 22:59 1549package sample.xml; import o ... -
swagger 实现文件上传
2016-06-01 22:23 5676@ResponseBody @RequestMa ... -
swagger
2016-06-01 21:18 0import static springfox.docum ... -
java
2016-05-26 01:14 0swagger2.0 -
swagger
2016-05-26 00:32 0spring swagger -
java 域名解析
2016-05-18 23:18 470import java.net.InetAddress;im ... -
swing 模拟文件上传
2016-05-15 17:32 502swing 模拟文件上传
相关推荐
Java解析XML时,dom4j是一个非常流行的库,它提供了灵活且强大的API来处理XML文档。dom4j-1.6.1.jar是这个库的一个版本,发布于2005年,它支持XML的读取、写入、操作以及查询功能。在本文中,我们将深入探讨dom4j的...
当我们需要将XML字符串解析并映射到Java Bean对象时,dom4j是一个常用的库。本篇文章将详细探讨如何使用dom4j库实现这个过程。 首先,dom4j是一个强大的Java XML API,它提供了丰富的功能,如读取、写入、修改和...
本篇将详细介绍使用DOM4j.Jar和JDOM.jar这两个Java库来解析XML文件的方法。 **DOM4j** DOM4j是一个灵活且功能强大的Java XML API,它提供了全面的XML处理解决方案,包括读取、写入、操作和转换XML文档。DOM4j的...
在Java中,我们可以使用DOM4J来解析XML字符串,以下是一个简单的步骤: 1. **导入DOM4J库**:确保项目中已经引入了DOM4J的依赖,如果没有,可以添加对应的Maven或Gradle依赖。 2. **读取XML字符串**:从文件、网络...
1. **解析XML**:DOM4J可以读取XML文件,将其转换为一个树形结构,即Document对象。解析器有SAX和DOM两种模式,SAX是事件驱动的,适用于大文件,而DOM则将整个文档加载到内存中,适合小文件。 2. **创建XML**:DOM4...
在生成XML字符串时,DOM4J提供了简洁的API来构建和输出XML文档。 4. JDOM JDOM是另一个Java的XML处理库,它专注于提供纯Java解决方案。JDOM提供了一个基于树的API,类似于DOM,但设计更简洁,易于使用。与DOM相比,...
1、xml文档解析 2、 dom4j解析xml 3、实现xml文件解析 xml字符串解析 xml MAP键值对解析 4、实现xml写入与生成文件
**DOM4J 读取XML字符串** DOM4J 是一个非常强大的 Java XML API,它提供了丰富的功能,使得处理 XML 文件变得更加简单。DOM4J 的设计理念是简洁、灵活且高性能,它支持 SAX 和 DOM 解析,并提供了面向对象的接口。...
`xmlToMap`方法首先使用SAXReader解析XML字符串,然后递归地遍历XML文档的元素,将它们转换为Map结构。 `mapToXml`方法则将Map转换成XML字符串: ```java import org.dom4j.Document; import org.dom4j....
本文将深入探讨XML数据在前后台解析的过程中,重点介绍两种主流的Java XML解析库——JDOM和DOM4J,并提供实际运行的程序示例。同时,我们还会讨论如何使用jQuery在前端解析XML并展示数据。 首先,让我们了解XML的...
DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活且高效的API,使得XML的解析、创建、修改变得更加简单。在这个场景中,我们关注的是如何使用DOM4J以String的形式读取XML内容,然后将String的值赋给XML...
通过DOM4J解析XML字符串是Java开发中处理XML数据的常见方法。DOM4J是一个非常灵活的用于处理XML、HTML和XSLT的Java库,它提供了丰富的API来操作XML文档,包括创建、读取、修改和遍历XML文档。在本文中,我们将深入...
在这个实例中,我们使用dom4j的DocumentHelper类来解析XML字符串。首先,我们import dom4j的相关类,包括Document、DocumentException、DocumentHelper和Element等。然后,我们使用DocumentHelper.parseText方法来...
这段代码首先使用`DocumentHelper.parseText`方法解析XML字符串,然后获取根元素并打印其名称,最后找到名为`element`的子元素并输出其内容。 总的来说,DOM4J结合Jaxen库为Java开发者提供了强大且灵活的XML处理...
DOM4J是一个强大的Java库,用于处理XML文档,包括读取、写入、修改和解析。本篇文章将深入探讨如何利用DOM4J解析SOAP消息中的元素,以便在实际项目中进行有效的数据提取和操作。 首先,理解SOAP消息的结构至关重要...
在这个例子中,我们首先使用DOM4J的`DocumentHelper.parseText`方法解析XML字符串,然后创建一个`DOMXPath`对象并使用XPath表达式"/root/element"找到`root`元素下的第一个`element`元素。接着,我们改变这个元素的...
// 输出XML字符串 System.out.println(document.asXML()); } } ``` 这段代码将创建一个简单的XML文档,其中包含一个名为"root"的根元素,根元素下有一个名为"child"的子元素,其内容为"Hello, World!"。 总结,...
在提供的源码中,我们可以看到如何使用DOM4J来解析XML文件。例如,以下代码展示了如何读取XML文件并打印根元素: ```java import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.io....