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的子类的对象
当形参是接口类型,那么实参是实现了该接口的类的对象。