XML编程(CRUD)

XML编程(CRUD)

一、JAXP

1、JAXP 开发包是J2SE的一部分,它由javax.xml、org.w3c.dom 、org.xml.sax 包及其子包组成

在javax.xml.parsers 包中,定义了几个工厂类,程序员调用这些工厂类,可以得到对xml文档进行解析的 DOM 或 SAX 的解析器对象。

2、使用JAXP进行DOM解析

javax.xml.parsers 包中的DocumentBuilderFactory用于创建DOM模式的解析器对象 , DocumentBuilderFactory是一个抽象工厂类,它不能直接实例化,但该类提供了一个newInstance方法 ,这个方法会根据本地平台默认安装的解析器,自动创建一个工厂的对象并返回。

3、 获得JAXP中的DOM解析器

(1)      调用 DocumentBuilderFactory.newInstance() 方法得到创建 DOM 解析器的工厂。

(2)      调用工厂对象的 newDocumentBuilder方法得到 DOM 解析器对象。

(3)      调用 DOM 解析器对象的 parse()方法解析 XML 文档,得到代表整个文档的 Document 对象,进行可以利用DOM特性对整个XML文档进行操作了。

二、DOM编程

1、DOM模型(document object model)

Ø        DOM解析器在解析XML文档时,会把文档中的所有元素,按照其出现的层次关系,解析成一个个Node对象(节点)。

Ø        在dom中,节点之间关系如下:

²       位于一个节点之上的节点是该节点的父节点(parent)

²       一个节点之下的节点是该节点的子节点(children)

²       同一层次,具有相同父节点的节点是兄弟节点(sibling)

²       一个节点的下一个层次的节点集合是节点后代(descendant)

²       父、祖父节点及所有位于节点上面的,都是节点的祖先(ancestor)

Ø        节点类型

三、Node对象

1、Node对象提供了一系列常量来代表结点的类型,当开发人员获得某个Node类型后,就可以把Node节点转换成相应的节点对象(Node的子类对象),以便于调用其特有的方法。(查看API文档)

2、 Node对象提供了相应的方法去获得它的父结点或子结点。编程人员通过这些方法就可以读取整个XML文档的内容、或添加、修改、删除XML文档的内容了。

四、添加节点【重点】

//节点的添加

       publicstatic void createElement(Document doc) throws Exception{

              //确定添加节点的位置:父节点

              Nodebook=doc.getElementsByTagName("书").item(0);

              //生成一个新节点

              Elementelement=doc.createElement("出版社");

              //element.setTextContent("清华大学");

              Texttext=doc.createTextNode("清华大学出版社");

              element.appendChild(text);

              //在指定位置把新生成的节点添加进去

              book.appendChild(element);

              //将内存中树状的结构doc把写入到xml文件

              //(1)生成工厂对象

              TransformerFactoryfactory=TransformerFactory.newInstance();

              //(2)由工厂对象生成转换对象Transformer

              Transformertrans=factory.newTransformer();

              //(3)通过trans实现doc转换到xml文档中,需要一个DOMSource对象代表源树

              trans.transform(newDOMSource(doc),new StreamResult(new File("src/book.xml")) );

       }

       publicstatic void createFixedElement(Document doc) throws Exception{

              //确定插入点的位置

              Nodeauthor=doc.getElementsByTagName("作者").item(0);

              Nodeparent=author.getParentNode();

              Nodebrother=author.getNextSibling();

              //创建一个新节点

              Elementelement=doc.createElement("出版社");

              element.setTextContent("清华大学出版社");

             

              //插入节点:在书这个节点中在作者节点之前添加了出版社

              parent.insertBefore(element,brother);

             

                           

              //将内存中树状的结构doc把写入到xml文件

              //(1)生成工厂对象

              TransformerFactoryfactory=TransformerFactory.newInstance();

              //(2)由工厂对象生成转换对象Transformer

              Transformertrans=factory.newTransformer();

              //(3)通过trans实现doc转换到xml文档中,需要一个DOMSource对象代表源树

              trans.transform(newDOMSource(doc),new StreamResult(new File("src/book.xml")) );

       }

五、删除结点

public static void deleteElement(Documentdoc) throws Exception{

              //获取要删除的那个节点对象

              Nodenode=doc.getElementsByTagName("售价").item(1);

              node.getParentNode().removeChild(node);

             

             

              //将内存中树状的结构doc把写入到xml文件

              //(1)生成工厂对象

              TransformerFactoryfactory=TransformerFactory.newInstance();

              //(2)由工厂对象生成转换对象Transformer

              Transformertrans=factory.newTransformer();

              //(3)通过trans实现doc转换到xml文档中,需要一个DOMSource对象代表源树

              trans.transform(newDOMSource(doc),new StreamResult(new File("src/book.xml")) );

       }

六、修改节点

public static void updateElement(Documentdoc) throws Exception{

              //获取要修改的那个节点

              Nodenode=doc.getElementsByTagName("售价").item(0);

              node.setTextContent("50");

              if(nodeinstanceof Element){

                     Elementelement=(Element)node;

                     Attratt=element.getAttributeNode("type");

                     att.setValue("美元");

              }

             

             

              //将内存中树状的结构doc把写入到xml文件

              //(1)生成工厂对象

              TransformerFactoryfactory=TransformerFactory.newInstance();

              //(2)由工厂对象生成转换对象Transformer

              Transformertrans=factory.newTransformer();

              //(3)通过trans实现doc转换到xml文档中,需要一个DOMSource对象代表源树

              trans.transform(newDOMSource(doc),new StreamResult(new File("src/book.xml")) );

       }

 

<书名>jsp</书名>

Node节点node           node.getNodeType()  类型

——元素element         node.getNodeName() 名称

                                   node.getNodeValue()  返回的为NULL  因为Element节点,所以nodeValue值为null

node.getTextContent  jsp程序设计

Texttext=(Test)node.getChildNodes().item(0);

Text.getNodeValue();——jsp程序设计  因为文本节点,所以nodeValue值,是jsp程序设计

 

1 类型 2 元素 3 文本

void func(Node node){

       //

}

Node是接口类型

func(doc);实参:可以是Node类型对象,还可以是Node的子类的对象

当形参是接口类型,那么实参是实现了该接口的类的对象。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值