*设为首页
*加入收藏
热门关键字: JAVA
>>当前位置:Java大本营>JAVA与XML>文章内容
java中用dom解析xml经典入门
作者: 发布时间:2007-11-23 06:39:50

一、前言

用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                              if(node.getNodeName().equals("price")){
26                                  String price=node.getFirstChild().getNodeValue();
27             System.out.println(price);
28               }
29                          }
30                      }
31                  }
32              }
33        }
34    } catch (ParserConfigurationException e) {
35      e.printStackTrace();
36    } catch (FileNotFoundException e) {
37      e.printStackTrace();
38    } catch (SAXException e) {
39      e.printStackTrace();
40    } catch (IOException e) {
41      e.printStackTrace();
42        }
43    }
44    public static void main(String[] args) {
45        new DomParse();
46    }
47 }

四、代码解释

先看看这个程序引用类:
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;

//下面主要是org.xml.sax包的类

共2页: 上一页 1 [2] 下一页

· mysql字符集问题(11-02)
· 排序算法java实现(11-02)
· 如何绑定Command的快捷键到上下文(11-02)
· JSP+MYSQL+Java类优化分页(09-03)
· hibernate3学习笔记(十九)|关系映射(09-03)
· hibernate3学习笔记(二十)|关系映射(09-03)
· 初探quartz scheduler (09-03)
· mysql数据库用jsp生成xml文件(09-02)
·Java中四种XML解析技术(05-21)
·XML解析技术 (03-20)
·java中用dom解析xml(02-02)
·如何用Java实现基于XML的购物车 (01-21)
复制地址发给您的好友: [推荐文章] [返回顶部] [关闭窗口]
版权所有 Java大本营 1999-2007 转载请注明出处