一、前言
用 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);
8###################
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);