`
Java_大猫
  • 浏览: 173087 次
  • 性别: Icon_minigender_1
  • 来自: 大连
社区版块
存档分类
最新评论

【转】Java与XML联合编程之DOM篇

    博客分类:
  • J2SE
阅读更多
DOM初步
  DOM是Document Object Model的缩写,即文档对象模型。前面说过,XML将数据组织为一颗树,所以DOM就是对这颗树的一个对象描叙。通俗的说,就是通过解析XML文档,为XML文档在逻辑上建立一个树模型,树的节点是一个个对象。我们通过存取这些对象就能够存取XML文档的内容。
  下面我们来看一个简单的例子,看看在DOM中,我们是如何来操作一个XML文档的。
  这是一个XML文档,也是我们要操作的对象:
  xml version="1.0" encoding="UTF-8"?>
  
  Good-bye serialization, hello Java!
  
  下面,我们需要把这个文档的内容解析到一个个的Java对象中去供程序使用,利用JAXP,我们只需几行代码就能做到这一点。首先,我们需要建立一个解析器工厂,以利用这个工厂来获得一个具体的解析器对象:
  DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
  我们在这里使用DocumentBuilderFacotry的目的是为了创建与具体解析器无关的程序,当DocumentBuilderFactory类的静态方法newInstance()被调用时,它根据一个系统变量来决定具体使用哪一个解析器。又因为所有的解析器都服从于JAXP所定义的接口,所以无论具体使用哪一个解析器,代码都是一样的。所以当在不同的解析器之间进行切换时,只需要更改系统变量的值,而不用更改任何代码。这就是工厂所带来的好处。这个工厂模式的具体实现,可以参看下面的类图。
  DocumentBuilder db = dbf.newDocumentBuilder();
  当获得一个工厂对象后,使用它的静态方法newDocumentBuilder()方法可以获得一个DocumentBuilder对象,这个对象代表了具体的DOM解析器。但具体是哪一种解析器,微软的或者IBM的,对于程序而言并不重要。
  然后,我们就可以利用这个解析器来对XML文档进行解析了:
  Document doc = db.parse("c:/xml/message.xml");
  DocumentBuilder的parse()方法接受一个XML文档名作为输入参数,返回一个Document对象,这个Document对象就代表了一个XML文档的树模型。以后所有的对XML文档的操作,都与解析器无关,直接在这个Document对象上进行操作就可以了。而具体对Document操作的方法,就是由DOM所定义的了。
  

Interface Hierarchy

    org.w3c.dom.DOMConfiguration
    org.w3c.dom.DOMError
    org.w3c.dom.DOMErrorHandler
    org.w3c.dom.DOMImplementation
    org.w3c.dom.DOMImplementationList
    org.w3c.dom.DOMImplementationSource
    org.w3c.dom.DOMLocator
    org.w3c.dom.DOMStringList
    org.w3c.dom.NamedNodeMap
    org.w3c.dom.NameList
    org.w3c.dom.Node
        org.w3c.dom.Attr
        org.w3c.dom.CharacterData

            org.w3c.dom.Comment
            org.w3c.dom.Text

                org.w3c.dom.CDATASection
        org.w3c.dom.Document
        org.w3c.dom.DocumentFragment
        org.w3c.dom.DocumentType
        org.w3c.dom.Element
        org.w3c.dom.Entity
        org.w3c.dom.EntityReference
        org.w3c.dom.Notation
        org.w3c.dom.ProcessingInstruction
    org.w3c.dom.NodeList
    org.w3c.dom.TypeInfo
    org.w3c.dom.UserDataHandler


  Jaxp支持W3C所推荐的DOM 2。如果你对DOM很熟悉,那么下面的内容就很简单了:只需要按照DOM的规范来进行方法调用就可以。当然,如果你对DOM不清楚,也不用着急,后面我们会有详细的介绍。在这儿,你所要知道并牢记的是:DOM是用来描叙XML文档中的数据的模型,引入DOM的全部原因就是为了用这个模型来操作XML文档的中的数据。DOM规范中定义有节点(即对象)、属性和方法,我们通过这些节点的存取来存取XML的数据。
  从上面得到的Document对象开始,我们就可以开始我们的DOM之旅了。使用Document对象的getElementsByTagName()方法,我们可以得到一个NodeList对象,一个Node对象代表了一个XML文档中的一个标签元素,而NodeList对象,观其名而知其意,所代表的是一个Node对象的列表:
  NodeList nl = doc.getElementsByTagName("message");
  我们通过这样一条语句所得到的是XML文档中所有标签对应的Node对象的一个列表。然后,我们可以使用NodeList对象的item()方法来得到列表中的每一个Node对象:
  Node my_node = nl.item(0);
  当一个Node对象被建立之后,保存在XML文档中的数据就被提取出来并封装在这个Node中了。在这个例子中,要提取Message标签内的内容,我们通常会使用Node对象的getNodeValue()方法:
  String message = my_node.getFirstChild().getNodeValue();
  请注意,这里还使用了一个getFirstChild()方法来获得message下面的第一个子Node对象。虽然在message标签下面除了文本外并没有其它子标签或者属性,但是我们坚持在这里使用getFirseChild()方法,这主要和W3C对DOM的定义有关。W3C把标签内的文本部分也定义成一个Node,所以先要得到代表文本的那个Node,我们才能够使用getNodeValue()来获取文本的内容。
  现在,既然我们已经能够从XML文件中提取出数据了,我们就可以把这些数据用在合适的地方,来构筑应用程序。
  下面的内容,我们将更多的关注DOM,为DOM作一个较为详细的解析,使我们使用起来更为得心应手。
  DOM详解
  1.基本的DOM对象
  DOM的基本对象有5个:Document,Node,NodeList,Element和Attr。下面就这些对象的功能和实现的方法作一个大致的介绍。
  [[The No.5 Picture.]]
  Document对象代表了整个XML的文档,所有其它的Node,都以一定的顺序包含在Document对象之内,排列成一个树形的结构,程序员可以通过遍历这颗树来得到XML文档的所有的内容,这也是对XML文档操作的起点。我们总是先通过解析XML源文件而得到一个Document对象,然后再来执行后续的操作。此外,Document还包含了创建其它节点的方法,比如createAttribut()用来创建一个Attr对象。它所包含的主要的方法有:
  
  createAttribute(String):用给定的属性名创建一个Attr对象,并可在其后使用setAttributeNode方法来放置在某一个Element对象上面。
  
  createElement(String):用给定的标签名创建一个Element对象,代表XML文档中的一个标签,然后就可以在这个Element对象上添加属性或进行其它的操作。
  
  createTextNode(String):用给定的字符串创建一个Text对象,Text对象代表了标签或者属性中所包含的纯文本字符串。如果在一个标签内没有其它的标签,那么标签内的文本所代表的Text对象是这个Element对象的唯一子对象。
  
  getElementsByTagName(String):返回一个NodeList对象,它包含了所有给定标签名字的标签。
  
  getDocumentElement():返回一个代表这个DOM树的根节点的Element对象,也就是代表XML文档根元素的那个对象。
  
  Node对象是DOM结构中最为基本的对象,代表了文档树中的一个抽象的节点。在实际使用的时候,很少会真正的用到Node这个对象,而是用到诸如Element、Attr、Text等Node对象的子对象来操作文档。Node对象为这些对象提供了一个抽象的、公共的根。虽然在Node对象中定义了对其子节点进行存取的方法,但是有一些Node子对象,比如Text对象,它并不存在子节点,这一点是要注意的。Node对象所包含的主要的方法有:
  
  appendChild(org.w3c.dom.Node):为这个节点添加一个子节点,并放在所有子节点的最后,如果这个子节点已经存在,则先把它删掉再添加进去。
  
  getFirstChild():如果节点存在子节点,则返回第一个子节点,对等的,还有getLastChild()方法返回最后一个子节点。
  
  getNextSibling():返回在DOM树中这个节点的下一个兄弟节点,对等的,还有getPreviousSibling()方法返回其前一个兄弟节点。
  
  getNodeName():根据节点的类型返回节点的名称。
  
  getNodeType():返回节点的类型。
  
  getNodeValue():返回节点的值。
  
  hasChildNodes():判断是不是存在有子节点。
  
  hasAttributes():判断这个节点是否存在有属性。
  
  getOwnerDocument():返回节点所处的Document对象。
  
  insertBefore(org.w3c.dom.Node new,org.w3c.dom.Node ref):在给定的一个子对象前再插入一个子对象。
  removeChild(org.w3c.dom.Node):删除给定的子节点对象。
  
  replaceChild(org.w3c.dom.Node new,org.w3c.dom.Node old):用一个新的Node对象代替给定的子节点对象。
  
  NodeList对象,顾名思义,就是代表了一个包含了一个或者多个Node的列表。可以简单的把它看成一个Node的数组,我们可以通过方法来获得列表中的元素:
  
  GetLength():返回列表的长度。
  
  Item(int):返回指定位置的Node对象。
  
  Element对象代表的是XML文档中的标签元素,继承于Node,亦是Node的最主要的子对象。在标签中可以包含有属性,因而Element对象中有存取其属性的方法,而任何Node中定义的方法,也可以用在Element对象上面。
  getElementsByTagName(String):返回一个NodeList对象,它包含了在这个标签中其下的子孙节点中具有给定标签名字的标签。
  
  getTagName():返回一个代表这个标签名字的字符串。
  
  getAttribute(String):返回标签中给定属性名称的属性的值。在这儿需要主要的是,应为XML文档中允许有实体属性出现,而这个方法对这些实体属性并不适用。这时候需要用到getAttributeNodes()方法来得到一个Attr对象来进行进一步的操作。
  
  getAttributeNode(String):返回一个代表给定属性名称的Attr对象。
  
  Attr对象代表了某个标签中的属性。Attr继承于Node,但是因为Attr实际上是包含在Element中的,它并不能被看作是Element的子对象,因而在DOM中Attr并不是DOM树的一部分,所以Node中的getparentNode(),getpreviousSibling()和getnextSibling()返回的都将是null。也就是说,Attr其实是被看作包含它的Element对象的一部分,它并不作为DOM树中单独的一个节点出现。这一点在使用的时候要同其它的Node子对象相区别。
  需要说明的是,上面所说的DOM对象在DOM中都是用接口定义的,在定义的时候使用的是与具体语言无关的IDL语言来定义的。因而,DOM其实可以在任何面向对象的语言中实现,只要它实现了DOM所定义的接口和功能就可以了。同时,有些方法在DOM中并没有定义,是用IDL的属性来表达的,当被映射到具体的语言时,这些属性被映射 
分享到:
评论

相关推荐

    Java与XML联合编程之DOM篇

    Java与XML联合编程之DOM篇 JAVA xml domJava与XML联合编程之DOM篇 JAVA xml domJava与XML联合编程之DOM篇 JAVA xml dom

    Java与XML联合编程之DOM篇.doc

    Java与XML联合编程的核心在于将XML文档转换为可操作的对象模型,这就是DOM(Document Object Model)的作用。DOM是一种标准,它定义了一种树形结构来表示XML文档,并提供了API以便程序能够读取、修改和创建XML文档。...

    Java与XML联合编程之DOM篇.rar_dom xml_dom xml java_java xml

    总的来说,DOM在Java与XML的联合编程中提供了一种强大且灵活的机制,使得开发者可以方便地解析、创建和修改XML文档。通过深入理解和熟练运用DOM,可以提高XML处理的效率和代码的可维护性。在实际项目中,选择适合的...

    Java与XML联合编程之SAX篇

    ### Java与XML联合编程之SAX篇 #### SAX概述 SAX(Simple API for XML)是一种用于解析XML文档的技术,虽然并非由W3C官方发布,但在实际应用中被广泛采纳,成为了一种非正式的标准。SAX适用于文档非常大的情况,...

    java+xml联合编程简单例子

    这个“java+xml联合编程简单例子”很可能包含了一个简单的Java应用程序,该程序使用了XML来存储或传递数据,并通过Java的API来解析和处理这些XML数据。以下是一些可能涉及的关键知识点: 1. **DOM(Document Object...

    Java与XML联合编程

    ### Java与XML联合编程知识点详解 #### 一、引言 在现代软件开发中,XML(Extensible Markup Language,可扩展标记语言)作为一种通用的数据交换格式,在不同平台间传输数据时发挥着重要作用。Java作为一门广泛应用...

    Java与XML读写之DOM篇

    Java与XML的交互是开发中常见的情景,特别是在处理配置文件、数据交换或者...了解和掌握DOM模型以及相关的API,对于进行XML编程至关重要。在实际开发中,根据需求选择合适的XML处理技术,能够提高代码的效率和灵活性。

    java xml和map互转

    总结,使用DOM4J库,我们可以方便地在Java中实现XML与Map之间的互转。这不仅适用于简单的键值对,还支持嵌套结构、属性以及有无根节点的情况。在实际项目中,可以根据具体需求对这些方法进行适当的调整和优化。

    Java创建xml文档笔记(DOM,DOM4J)

    在Java编程中,XML(可扩展标记语言)是一种被广泛用于数据存储和交换的格式,尤其是在Web服务和配置文件中。本笔记将深入探讨如何使用DOM(文档对象模型)和DOM4J库来创建XML文档。 一、DOM解析器 DOM是W3C推荐的...

    java list和xml互转例子

    在Java编程中,数据结构和数据格式的转换是常见的任务之一。本示例涉及的核心知识点是将Java中的List对象与XML文档进行相互转换。这里,我们使用的库是dom4j-1.6.1.jar,这是一个强大的Java XML处理库。 首先,让...

    Java DOM 生成XML

    Java DOM(Document Object Model)是一种基于树形结构的XML文档处理模型,它允许程序员通过对象接口来访问和操作XML文档的各个部分。DOM为XML文档提供了一种内存中的表示方式,使得开发人员可以方便地创建、修改和...

    java的xml编程(Dom)xmlReanAndWrite.rar-基本操作

    Java的XML编程主要涉及到对XML文档的解析、创建和修改,而DOM(Document Object Model)是一种常见的处理XML的标准API。本教程重点讲解基于DOM的Java XML编程基础操作,旨在通过简单示例帮助开发者掌握XML的基本读写...

    Java XML编程指南

    Java XML编程指南是一本专为初学者设计的教程,旨在帮助读者掌握XML(eXtensible Markup Language)在Java环境中的应用。XML是一种用于标记数据的语言,广泛应用于数据交换、配置存储、文档描述等多个领域。Java与...

    Java and XML(英文第三版)_java_xml_birdsolc_源码

    《Java and XML(英文第三版)_java_xml_birdsolc_源码》是关于Java与XML集成编程的一本权威指南,特别适合于那些希望深入理解如何在Java应用程序中有效地使用XML技术的开发者。这本书详细阐述了Java平台上的XML处理...

    java一键xml转map,一键map转xml工具类

    在Java编程中,XML(可扩展标记语言)和Map(映射)是两种常见的数据存储和交换格式。XML因其结构化和易于解析的特性,在数据交换和配置文件中广泛使用,而Map则作为Java中存储键值对的高效数据结构。在实际开发中,...

    java XML 编程指南

    Java XML编程指南主要涵盖的是如何在Java环境中处理XML(可扩展标记语言)文档的技术和实践。XML作为一种数据交换和存储格式,在Web服务、配置文件、数据序列化等领域广泛应用。本指南将深入探讨Java与XML的集成,...

    java_xml编程指南

    《Java XML编程指南》是一本面向Java开发人员的实用教程,旨在帮助读者深入理解XML(eXtensible Markup Language)在Java环境中的应用。XML作为一种数据交换格式,因其灵活性和可扩展性,广泛用于Web服务、配置文件...

Global site tag (gtag.js) - Google Analytics