竹里馆→忆童年

独坐幽篁里,弹琴复长啸;深林人不知,明月来相照
posts - 9, comments - 23, trackbacks - 0, articles - 0
   :: 首页 :: 新随笔 :: 联系 ::  :: 管理

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

Posted on 2007-07-20 13:13 忆童年 阅读(7425) 评论(4)  编辑  收藏 所属分类: XML and WebService

这是我最近做项目时遇到的问题
   我是通过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文件

评论

# re: JDOM解析XML字符串(非XML文档)  回复  更多评论   

2007-07-20 16:36 by sitinspring
让我想起了寒冬做JMS的岁月.

# re: JDOM解析XML字符串(非XML文档)  回复  更多评论   

2007-10-17 17:09 by xb
thank you

# re: JDOM解析XML字符串(非XML文档)  回复  更多评论   

2008-10-30 16:01 by 战斗中的人
非常感谢你的文章

# re: JDOM解析XML字符串(非XML文档)  回复  更多评论   

2010-11-08 14:29 by www
thank you~~

只有注册用户登录后才能发表评论。


网站导航: