JDOM解析XML字符串(非XML文档)

这是我最近做项目时遇到的问题
   我是通过JMS机制获得Topic的消息其消息格式是XML.本想将其写成XML文档再通过JDOM读取.但考虑到实际开发中消息传递频繁就放弃了该思路.最终采取了直接对其分析的方式,这样就必须对取得的TextMessage做处理
   如下是我通过JDOM方式将得到的TextMessage(XML格式)进行解析的过程:

package  cmo.shubai.jdom;

import  java.io.IOException;
import  java.io.StringReader;
import  java.util.List;

import  org.jdom.Document;
import  org.jdom.Element;
import  org.jdom.JDOMException;
import  org.jdom.Namespace;
import  org.jdom.input.SAXBuilder;
import  org.xml.sax.InputSource;

public   class  DuXMLDoc  {
    
public List xmlElements(String xmlDoc) {
        
//创建一个新的字符串
        StringReader read = new StringReader(xmlDoc);
        
//创建新的输入源SAX 解析器将使用 InputSource 对象来确定如何读取 XML 输入
        InputSource source = new InputSource(read);
        
//创建一个新的SAXBuilder
        SAXBuilder sb = new SAXBuilder();
        
try {
            
//通过输入源构造一个Document
            Document doc = sb.build(source);
            
//取的根元素
            Element root = doc.getRootElement();
            System.out.println(root.getName());
//输出根元素的名称(测试)
            
//得到根元素所有子元素的集合
            List jiedian = root.getChildren();
            
//获得XML中的命名空间(XML中未定义可不写)
            Namespace ns = root.getNamespace();
            Element et 
= null;
            
for(int i=0;i<jiedian.size();i++){
                et 
= (Element) jiedian.get(i);//循环依次得到子元素
                /**//*
                 * 无命名空间定义时
                 * et.getChild("users_id").getText();
                 * et.getChild("users_address",ns).getText()
                 
*/

                System.out.println(et.getChild(
"users_id",ns).getText());
                System.out.println(et.getChild(
"users_address",ns).getText());
            }

            
/**//*
             * 如要取<row>下的子元素的名称
             
*/

            et 
= (Element) jiedian.get(0);
            List zjiedian 
= et.getChildren();
            
for(int j=0;j<zjiedian.size();j++){
                Element xet 
= (Element) zjiedian.get(j);
                System.out.println(xet.getName());
            }

        }
 catch (JDOMException e) {
            
// TODO 自动生成 catch 块
            e.printStackTrace();
        }
 catch (IOException e) {
            
// TODO 自动生成 catch 块
            e.printStackTrace();
        }

        
return null;
    }

    
public static void main(String[] args){
        DuXMLDoc doc 
= new DuXMLDoc();
        String xml 
= "<?xml version=\"1.0\" encoding=\"gb2312\"?>"+
        
"<Result xmlns=\"http://www.fiorano.com/fesb/activity/DBQueryOnInput2/Out\">"+
           "<row resultcount=\"1\">"+
              
"<users_id>1001     </users_id>"+
              
"<users_name>wangwei   </users_name>"+
              
"<users_group>80        </users_group>"+
              
"<users_address>1001号   </users_address>"+
           
"</row>"+
           
"<row resultcount=\"1\">"+
              
"<users_id>1002     </users_id>"+
              
"<users_name>wangwei   </users_name>"+
              
"<users_group>80        </users_group>"+
              
"<users_address>1002号   </users_address>"+
           
"</row>"+
        
"</Result>";
        doc.xmlElements(xml);
    }

}


以上的例子和实际稍有出入-这个例子主要是用来演示JDOM解析XML字符串
关于JDOM对XML文档的解析可看JDOM处理带Namespace的XML文件


你可能感兴趣的:(JDOM解析XML字符串(非XML文档))