1 /**功能说明 报文解析
2 * @param
3 * @author
4 * @since
5 */
6 package com.mall.common;
7
8 import java.io.IOException;
9 import java.io.StringReader;
10 import java.util.List;
11
12 import org.jdom.Document;
13 import org.jdom.Element;
14 import org.jdom.JDOMException;
15 import org.jdom.Namespace;
16 import org.jdom.input.SAXBuilder;
17 import org.xml.sax.InputSource;
18
19
20 public class DuXMLDoc {
21 @SuppressWarnings("unchecked")
22 public List xmlElements(String xmlDoc) {
23 //创建一个新的字符串
24 StringReader read = new StringReader(xmlDoc);
25 //创建新的输入源SAX 解析器将使用 InputSource 对象来确定如何读取 XML 输入
26 InputSource source = new InputSource(read);
27 //创建一个新的SAXBuilder
28 SAXBuilder sb = new SAXBuilder();
29 try {
30 //通过输入源构造一个Document
31 Document doc = sb.build(source);
32 //取的根元素
33 Element root = doc.getRootElement();
34 System.out.println("根元素的名称:"+root.getName());//输出根元素的名称(测试)
35 //得到根元素所有子元素的集合
36 List jiedian = root.getChildren();
37 //获得XML中的命名空间(XML中未定义可不写)
38 Namespace ns = root.getNamespace();
39 Element et = null;
40 for(int i=0;i<jiedian.size();i++){
41 et = (Element) jiedian.get(i);//循环依次得到子元素
42 /**//*
43 * 无命名空间定义时
44 * et.getChild("users_id").getText();
45 * et.getChild("users_address",ns).getText()
46 */
47 System.out.println(et.getChild("users_id",ns).getText());
48 System.out.println(et.getChild("users_address",ns).getText());
49 }
50 /**//*
51 * 如要取<row>下的子元素的名称
52 */
53 et = (Element) jiedian.get(0);
54 List zjiedian = et.getChildren();
55 for(int j=0;j<zjiedian.size();j++){
56 Element xet = (Element) zjiedian.get(j);
57 System.out.println(xet.getName());
58 }
59 } catch (JDOMException e) {
60 // TODO 自动生成 catch 块
61 e.printStackTrace();
62 } catch (IOException e) {
63 // TODO 自动生成 catch 块
64 e.printStackTrace();
65 }
66 return null;
67 }
68 public static void main(String[] args){
69 DuXMLDoc doc = new DuXMLDoc();
70 String xml = "<?xml version=\"1.0\" encoding=\"gb2312\"?>"+
71 "<Result xmlns=\"http://www.fiorano.com/fesb/activity/DBQueryOnInput2/Out\">"+
72 "<row resultcount=\"1\">"+
73 "<users_id>1001 </users_id>"+
74 "<users_name>wangwei </users_name>"+
75 "<users_group>80 </users_group>"+
76 "<users_address>1001号 </users_address>"+
77 "</row>"+
78 "<row resultcount=\"1\">"+
79 "<users_id>1002 </users_id>"+
80 "<users_name>wangwei </users_name>"+
81 "<users_group>80 </users_group>"+
82 "<users_address>1002号 </users_address>"+
83 "</row>"+
84 "</Result>";
85 doc.xmlElements(xml);
86 }
87
88 }