java解析(操作)XML文件之DOM解析

package com.jonw.dao;

import java.io.File;
import java.io.IOException;
import java.io.Writer;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerConfigurationException;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import javax.xml.xpath.XPath;
import javax.xml.xpath.XPathConstants;
import javax.xml.xpath.XPathExpression;
import javax.xml.xpath.XPathExpressionException;
import javax.xml.xpath.XPathFactory;

import org.dom4j.io.OutputFormat;
import org.dom4j.io.XMLWriter;
import org.w3c.dom.Document;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;

public class PraseXML {
private static String filename = null;// 文件名
private static DocumentBuilderFactory fac = null;
private static DocumentBuilder bu = null;
private static Document doc;// 文档模型
private static XPath xml = null;
private static TransformerFactory tff = null;//文檔轉鐵器
private static Transformer tf = null;
private static DOMSource dom = null;
private static StreamResult sr = null;
private static PraseXML InstancesPraseXML = null;// 單例

/**
* 初始化成員變量
*/
private PraseXML() {
   this.filename = new String(PraseXMLStatic.PATH);
   beforePraseXML();
}

/**
* 單例此對象的一個實例
* 
* @return PraseXML
*/
public static PraseXML getInstancesPraseXML() {
   if (InstancesPraseXML == null)
    return new PraseXML();
   return InstancesPraseXML;
}

/**
* 返回name的所有結點
* 
* @param name
* @return NodeList
*/
public NodeList getObjectInstances(String name) {
   try {
    XPathExpression exp = xml.compile("//"+name);//匹配所有的Service結點
    Object obj = exp.evaluate(doc, XPathConstants.NODESET);
    NodeList list = (NodeList) obj;

    for (int i = 0; i < list.getLength(); i++) {
     System.out.println(list.item(i).getAttributes().getNamedItem(
       "name").getNodeValue());//輸出Serive結點的屬性
     list.item(i).getAttributes().getNamedItem("name").setNodeValue(
       "jonw");//修改Service結點的屬性

    }

    this.afterPraseXML();//善後處理
    return list;//近回所有的Service結點
   } catch (Exception e) {
    System.out.println("*****************");
    return null;
   }

}

/**
* 在进行所有增删改查的操作前的准备工作
*/
private void beforePraseXML() {
   try {
    fac = DocumentBuilderFactory.newInstance();//獲得一個XML文檔解析器
    bu = fac.newDocumentBuilder();//解析XML文件得到一個DOM文檔類接口,以便訪問DOM
    doc = bu.parse("src/server.xml");//初始化DOCUMENT對象
    xml = XPathFactory.newInstance().newXPath();//創建一個XPATH對象

   } catch (Exception e) {
    System.out.println("實例化XML文件失敗");
   }
}

/**
* 在进行所有增删改查的操作后的善后处理
*/
public void afterPraseXML() {
   try {  
    tff = TransformerFactory.newInstance();//獲得將DOM文檔轉化成XML文件的轉換器
    tf = tff.newTransformer();
    dom = new DOMSource(doc);//將DOM文檔轉化為DOMsourse對象,
    sr = new StreamResult(new File("src/server.xml"));//獲得一個StreamResult類的對象,該對象是將XML文件轉換成其他對象的容器
    tf.transform(dom, sr);//調用API,將DOM轉化成XML文件
   } catch (Exception e) {
    System.out.println("保存XML文件失敗");
   }
}
/**
* 測試類
* @param a
*/
public static void main(String[] a) {
   PraseXML.getInstancesPraseXML().getObjectInstances("Service");
}

}


/*

nodename	选取此节点的所有子节点
/	从根节点选取
//	从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置
.	选取当前节点
..	选取当前节点的父节点
@	
选取属性



如:

bookstore	选取 bookstore 元素的所有子节点
/bookstore	
选取根元素 bookstore

注释:假如路径起始于正斜杠( / ),则此路径始终代表到某元素的绝对路径!
bookstore/book	选取所有属于 bookstore 的子元素的 book 元素。
//book	选取所有 book 子元素,而不管它们在文档中的位置。
bookstore//book	选择所有属于 bookstore 元素的后代的 book 元素,而不管它们位于 bookstore 之下的什么位置。
//@lang	选取所有名为 lang 的属性。


*/

你可能感兴趣的:(java,DAO,工作,xml)