dom4j是一种解析XML文档的开放源代码XML框架。本文利用dom4j的jar包,构建了一个解析xml文档的方法,首先构建web工程,在WebRoot/WEB-INF/lib下导入下载好的dom4j的jar包 ,建一个包,命名util,在util包下建一个Java类,ReadStringXml.java,代码如下
package util;
import java.util.List;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
public class ReadStringXml {
public void readStringXml(String xml){
try {
Document doc = DocumentHelper.parseText(xml);
Element root=doc.getRootElement();//获取根节点
this.getNodes(root);
} catch (DocumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
private void getNodes(Element node){
System.out.println("--------------------");
System.out.println("当前节点名称:"+node.getName());//当前节点名称
if(!(node.getTextTrim().equals(""))){
System.out.println("当前节点的内容:"+node.getTextTrim()); //当前节点文本内容
}
List<Attribute> listAttr=node.attributes();//当前节点的所有属性的list
for(Attribute attr:listAttr){//遍历当前节点的所有属性
String name=attr.getName();//属性名称
String value=attr.getValue();//属性的值
System.out.println("属性名称:"+name+"属性值:"+value);
}
//递归遍历当前节点所有的子节点
List<Element> listElement=node.elements();//所有一级子节点的list
for(Element e:listElement){//遍历所有一级子节点
this.getNodes(e);//递归
}
}
}
这个Java类中的方法是解析string型的xml文档,即xml格式的长字符串。大家可以自行写个test,测试下效果。感觉还是挺好使的。