一、前言
用Java解析XML文档,最常用的有两种方法:使用基于事件的XML简单API(Simple API for XML)称为SAX和基于树和节点的文档对象模型(Document Object Module)称为DOM。Sun公司提供了Java API for XML Parsing(JAXP)接口来使用SAX和DOM,通过JAXP,我们可以使用任何与JAXP兼容的XML解析器。
JAXP接口包含了三个包:
(1)org.w3c.dom W3C推荐的用于XML标准规划文档对象模型的接口。
(2)org.xml.sax 用于对XML进行语法分析的事件驱动的XML简单API(SAX)
(3)javax.xml.parsers解析器工厂工具,程序员获得并配置特殊的特殊语法分析器。
二、前提DOM编程不要其它的依赖包,由于JDK里自带的JDK里含有的上面提到的org.w3c.dom、org.xml.sax 和javax.xml.parsers包就可以满意条件了。
三、使用DOM解析XML文档我们如今来看看DOM是如何解析XML的吧!同样的,我将从一个简单的不能再简单的例子来说明DOM是如何解析XML文档的,先让我们看看XML是什么内容吧:
<?xml version="1.0" encoding="gb2312"?>
<books>
<book email="zhoujunhui">
<name>rjzjh</name>
<price>jjjjjj</price>
</book>
</books>
简单的不能再简单了。但是该有的都有了,根元素、属性、子节点。好了,能反应问题就行了,下面来看看解析这个XML文件的Java代码吧!
1 public class DomParse {
2 public DomParse(){
3 DocumentBuilderFactory domfac=DocumentBuilderFactory.newInstance();
4 try {
5 DocumentBuilder dombuilder=domfac.newDocumentBuilder();
6 InputStream is=new FileInputStream("bin/library.xml");
7 Document doc=dombuilder.parse(is);
9 Element root=doc.getDocumentElement();
10 NodeList books=root.getChildNodes();
11 if(books!=null){
12 for(int i=0;i<books.getLength();i++){
13 Node book=books.item(i);
14 if(book.getNodeType()==Node.ELEMENT_NODE){
15 String email=book.getAttributes().getNamedItem("email").getNodeValue();
16 System.out.println(email);
17 for(Node node=book.getFirstChild();node!=null;node=node.getNextSibling()){
18 if(node.getNodeType()==Node.ELEMENT_NODE){
19 if(node.getNodeName().equals("name")){
20 String name=node.getNodeValue();
21 String name1=node.getFirstChild().getNodeValue();
22 System.out.println(name);
23 System.out.println(name1);
24 }
25 &nbs