程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> JAVA編程入門知識 >> Java中文檔對象模型DOM經驗小結

Java中文檔對象模型DOM經驗小結

編輯:JAVA編程入門知識

  文檔對象模型 (DOM) 是一個文檔標准,對於完備的文檔和復雜的應用程序,DOM 提供了大量靈活性。DOM標准是標准的。它很強壯且完整,並且有許多實現。這是許多大型安裝的決定因素--非凡是對產品應用程序,以避免在API發生改變時進行大量的改寫。
  
   <!-- frame contents --> <!-- /frame contents -->   以上是我在選擇處理XML數據時之所以沒有選擇JDOM或者dom4j等其它面向對象的標准的原因,不過也由於DOM從一開始就是一種與語言無關的模型,而且它更趨向用於像C或Perl這類語言,沒有利用Java的面向對象的性能,所以在使用的過程中也碰到了不少的麻煩,今天這裡做一個小結。另外,我目前使用XML主要是作為數據傳輸的統一格式,並統一用戶界面展示的接口,應用的面並不是很廣,所以使用到的DOM的內容其實不多。
  
  在預備使用它的時候,是做了充足的預備的,也有碰到困難的預備,所以一開始就有了一個簡單的工具類來封裝DOM對象使用時必要的公共方法,實際證實這樣做是很明智的,一個簡單的創建Document對象的操作,要是每次都需要寫上5行以上代碼,並且還要處理那些煩人的Exception,實在是會打擊大家的積極性,所以在最初,做了一個XMLTool類,專門封裝了如下的公共方法:
  
  1、 Document對象創建(包括空的Document對象創建,以一個給定Node節點作為根節點創建。
  
  2、 將一個規范的XML字符串轉換成一個Document對象。
  
  3、 從物理硬盤讀取一個XML文件並返回一個Document對象。
  
  4、 將一個Node對象轉換成字符串。
  
  其中每個方法都截獲相關的DOM操作所拋出的異常,轉換成一個RuntimeException拋出,這些異常在實際使用過程中,一般狀況下其實都不會拋出,非凡是象生成一個Document對象時的ParserConfigurationException、轉換Node節點成字符串時要生成一個Transformer對象時的TransformerConfigurationException等等,沒有必要在它們身上花時間精力。而且真就出了相關的異常的話,其實根本沒有辦法處理,這樣的狀況通常是系統環境配置有問題(比如必要的DOM實現解析器等包沒有加入環境),所以包裝該異常時只是很簡要的獲取其Message拋出。
  
  代碼如下:
  
   /**
  * 初始化一個空Document對象返回。
  * @return a Document
  */
  public static Document newXMLDocument() {
   try {
  return newDocumentBuilder().newDocument();
   } catch (ParserConfigurationException e) {
   throw new RuntimeException(e.getMessage());
   }
  }
  
  /**
  * 初始化一個DocumentBuilder
  * @return a DocumentBuilder
  * @throws ParserConfigurationException
  */
  public static DocumentBuilder newDocumentBuilder()
  throws ParserConfigurationException {
  return newDocumentBuilderFactory().newDocumentBuilder();
  }
  
  /**
  * 初始化一個DocumentBuilderFactory
  * @return a DocumentBuilderFactory
  */
  public static DocumentBuilderFactory newDocumentBuilderFactory() {
   DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
   dbf.setNamespaceAware(true);
   return dbf;
  }
  /**
  * 將傳入的一個XML String轉換成一個org.w3c.dom.Document對象返回。
  * @param xmlString 一個符合XML規范的字符串表達。
  * @return a Document
  */
  public static Document parseXMLDocument(String xmlString) {
   if (xmlString == null) {
  throw new IllegalArgumentException();
   }
   try {
  return newDocumentBuilder().parse(
   new InputSource(new StringReader(xmlString)));
   } catch (Exception e) {
  throw new RuntimeException(e.getMessage());
   }
  }
  
  /**
  * 給定一個輸入流,解析為一個org.w3c.dom.Document對象返回。
  
 
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved