`

java解析xml字符串(用dom4j)

    博客分类:
  • java
JVM 
阅读更多

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
分享到:
评论

相关推荐

    java解析XML dom4j dom4j-1.6.1.jar

    Java解析XML时,dom4j是一个非常流行的库,它提供了灵活且强大的API来处理XML文档。dom4j-1.6.1.jar是这个库的一个版本,发布于2005年,它支持XML的读取、写入、操作以及查询功能。在本文中,我们将深入探讨dom4j的...

    使用dom4j将xml字符串转换成Bean对象

    当我们需要将XML字符串解析并映射到Java Bean对象时,dom4j是一个常用的库。本篇文章将详细探讨如何使用dom4j库实现这个过程。 首先,dom4j是一个强大的Java XML API,它提供了丰富的功能,如读取、写入、修改和...

    JAVA 解析XML 的JAr包 DOM4j.Jar JDOM.jar

    本篇将详细介绍使用DOM4j.Jar和JDOM.jar这两个Java库来解析XML文件的方法。 **DOM4j** DOM4j是一个灵活且功能强大的Java XML API,它提供了全面的XML处理解决方案,包括读取、写入、操作和转换XML文档。DOM4j的...

    xml字符串解析

    在Java中,我们可以使用DOM4J来解析XML字符串,以下是一个简单的步骤: 1. **导入DOM4J库**:确保项目中已经引入了DOM4J的依赖,如果没有,可以添加对应的Maven或Gradle依赖。 2. **读取XML字符串**:从文件、网络...

    DOM4J jar包 xml解析 所有的dom4j-1.6.1 dom4j-2.0.2 dom4j-2.1.1包 导入直接使用

    1. **解析XML**:DOM4J可以读取XML文件,将其转换为一个树形结构,即Document对象。解析器有SAX和DOM两种模式,SAX是事件驱动的,适用于大文件,而DOM则将整个文档加载到内存中,适合小文件。 2. **创建XML**:DOM4...

    DOM、SAX、DOM4J、JDOM、StAX生成XML并返回XML字符串形式

    在生成XML字符串时,DOM4J提供了简洁的API来构建和输出XML文档。 4. JDOM JDOM是另一个Java的XML处理库,它专注于提供纯Java解决方案。JDOM提供了一个基于树的API,类似于DOM,但设计更简洁,易于使用。与DOM相比,...

    dom4j 解析写入xml

    1、xml文档解析 2、 dom4j解析xml 3、实现xml文件解析 xml字符串解析 xml MAP键值对解析 4、实现xml写入与生成文件

    DOM4J 读取xml字符串

    **DOM4J 读取XML字符串** DOM4J 是一个非常强大的 Java XML API,它提供了丰富的功能,使得处理 XML 文件变得更加简单。DOM4J 的设计理念是简洁、灵活且高性能,它支持 SAX 和 DOM 解析,并提供了面向对象的接口。...

    java xml和map互转

    `xmlToMap`方法首先使用SAXReader解析XML字符串,然后递归地遍历XML文档的元素,将它们转换为Map结构。 `mapToXml`方法则将Map转换成XML字符串: ```java import org.dom4j.Document; import org.dom4j....

    xml数据前后台解析:jdom与dom4j源码,程序可以跑

    本文将深入探讨XML数据在前后台解析的过程中,重点介绍两种主流的Java XML解析库——JDOM和DOM4J,并提供实际运行的程序示例。同时,我们还会讨论如何使用jQuery在前端解析XML并展示数据。 首先,让我们了解XML的...

    dom4j以String的方式读取XML的内容,并给String的值赋值,写入XML中

    DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活且高效的API,使得XML的解析、创建、修改变得更加简单。在这个场景中,我们关注的是如何使用DOM4J以String的形式读取XML内容,然后将String的值赋给XML...

    通过dom4j解析xml字符串(示例代码)

    通过DOM4J解析XML字符串是Java开发中处理XML数据的常见方法。DOM4J是一个非常灵活的用于处理XML、HTML和XSLT的Java库,它提供了丰富的API来操作XML文档,包括创建、读取、修改和遍历XML文档。在本文中,我们将深入...

    dom4j解析字符串

    在这个实例中,我们使用dom4j的DocumentHelper类来解析XML字符串。首先,我们import dom4j的相关类,包括Document、DocumentException、DocumentHelper和Element等。然后,我们使用DocumentHelper.parseText方法来...

    dom4j解析XML所需要的jar包

    这段代码首先使用`DocumentHelper.parseText`方法解析XML字符串,然后获取根元素并打印其名称,最后找到名为`element`的子元素并输出其内容。 总的来说,DOM4J结合Jaxen库为Java开发者提供了强大且灵活的XML处理...

    利用DOM4J解析SOAP的简单示例

    DOM4J是一个强大的Java库,用于处理XML文档,包括读取、写入、修改和解析。本篇文章将深入探讨如何利用DOM4J解析SOAP消息中的元素,以便在实际项目中进行有效的数据提取和操作。 首先,理解SOAP消息的结构至关重要...

    java解析xml用到的dom4j,jaxen包

    在这个例子中,我们首先使用DOM4J的`DocumentHelper.parseText`方法解析XML字符串,然后创建一个`DOMXPath`对象并使用XPath表达式"/root/element"找到`root`元素下的第一个`element`元素。接着,我们改变这个元素的...

    Java创建xml文档笔记(DOM,DOM4J)

    // 输出XML字符串 System.out.println(document.asXML()); } } ``` 这段代码将创建一个简单的XML文档,其中包含一个名为"root"的根元素,根元素下有一个名为"child"的子元素,其内容为"Hello, World!"。 总结,...

    dom4j解析xml详解,包含源代码,dom4j.jar包

    在提供的源码中,我们可以看到如何使用DOM4J来解析XML文件。例如,以下代码展示了如何读取XML文件并打印根元素: ```java import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.io....

Global site tag (gtag.js) - Google Analytics