<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 431,  comments - 344,  trackbacks - 0

    一、 JDOM  簡介
    JDOM
    是一個開源項目,它基于樹型結構,利用純 Java 的技術對 XML 文檔實現解析、生成、序列化以及多種操作。
    JDOM 
    直接為 Java 編程服務。它利用更為強有力的 Java 語言的諸多特性(方法重載、集合概念以及映射),把 SAX DOM 的功能有效地結合起來。
    在使用設計上盡可能地隱藏原來使用 XML 過程中的復雜性。利用 JDOM 處理 XML 文檔將是一件輕松、簡單的事。
    JDOM 
    2000 年的春天被 Brett McLaughlin Jason Hunter 開發出來,以彌補 DOM SAX 在實際應用當中的不足之處。
    這些不足之處主要在于 SAX 沒有文檔修改、隨機訪問以及輸出的功能,而對于 DOM 來說, Java 程序員在使用時來用起來總覺得不太方便。
    DOM
    的缺點主要是來自于由于 Dom 是一個接口定義語言( IDL , 它的任務是在不同語言實現中的一個最低的通用標準,并不是為 Java 特別設計的。 JDOM 的最新版本為 JDOM Beta 9 。最近 JDOM 被收錄到 JSR-102 內,這標志著 JDOM 成為了 Java 平臺組成的一部分。


    二、 JDOM  包概覽
    JDOM
    是由以下幾個包組成的
    org.JDOM
    org.JDOM.input
    org.JDOM.output
    org.JDOM.adapters
    org.JDOM.transform

    三、 JDOM  類說明

    org.JDOM
    這個包里的類是你解析 xml 文件后所要用到的所有數據類型。
    Attribute
    CDATA
    Coment
    DocType
    Document
    Element
    EntityRef
    Namespace
    ProscessingInstruction
    Text

    org.JDOM.transform
    在涉及 xslt 格式轉換時應使用下面的 2 個類
    JDOMSource
    JDOMResult

    org.JDOM.input
    輸入類,一般用于文檔的創建工作
    SAXBuilder
    DOMBuilder
    ResultSetBuilder

    org.JDOM.output
    輸出類,用于文檔轉換輸出
    XMLOutputter
    SAXOutputter
    DomOutputter
    JTreeOutputter

    使用前注意事項:
    1.JDOM
    對于 JAXP  以及  TRax  的支持
    JDOM 
    支持 JAXP1.1 :你可以在程序中使用任何的 parser 工具類 , 默認情況下是 JAXP parser
    制定特別的 parser 可用如下形式
    SAXBuilder parser 
    = new SAXBuilder("org.apache.crimson.parser.XMLReaderImpl");
    Document doc = parser.build("http://www.cafeconleche.org/");
    // work with the document...
    JDOM
    也支持 TRaX XSLT 可通過 JDOMSource 以及 JDOMResult 類來轉換(參見以后章節)
    2.
    注意在 JDOM 里文檔( Document )類由 org.JDOM.Document  來表示。這要與 org.w3c.dom 中的 Document 區別開,這 2 種格式如何轉換在后面會說明。
    以下如無特指均指 JDOM 里的 Document 。


    四、 JDOM 主要使用方法
    1.Ducument

    (1)Document
    的操作方法:
    Element root = new Element("GREETING");
    Document doc = new Document(root);
    root.setText("Hello JDOM!");
    或者簡單的使用 Document doc = new Document(new Element("GREETING").setText("Hello JDOM!t"));

    這點和 DOM 不同。 Dom 則需要更為復雜的代碼,如下:
    DocumentBuilderFactory factory =DocumentBuilderFactory.newInstance();
    DocumentBuilder builder =factory.newDocumentBuilder();
    Document doc = builder.newDocument();
    Element root =doc.createElement("root");
    Text text = doc.createText("This is the root");
    root.appendChild(text);
    doc.appendChild(root);


    注意事項: JDOM 不允許同一個節點同時被 2 個或多個文檔相關聯,要在第 2 個文檔中使用原來老文檔中的節點的話。首先需要使用 detach() 把這個節點分開來。

    (2)
    從文件、流、系統 ID 、 URL 得到 Document 對象:
    DOMBuilder builder = new DOMBuilder();
    Document doc = builder.build(new File("jdom_test.xml"));

    SAXBuilder builder = new SAXBuilder();
    Document doc = builder.build(url);
    在新版本中 DOMBuilder  已經 Deprecated  DOMBuilder.builder(url) ,用 SAX 效率會比較快。

    這里舉一個小例子,為了簡單起見,使用 String 對象直接作為 xml 數據源:

    public jdomTest() {
      String textXml = null;
      textXml = "<note>";
      textXml = textXml +
        "<to>aaa</to><from>bbb</from><heading>ccc</heading><body>ddd</body>";
      textXml = textXml + "</note>";
      SAXBuilder builder = new SAXBuilder();
      Document doc = null;
      Reader in= new StringReader(textXml);
      try {
        doc = builder.build(in);
        Element root = doc.getRootElement();
        List ls = root.getChildren();//
    注意此處取出的是 root 節點下面的一層的 Element 集合
        for (Iterator iter = ls.iterator(); iter.hasNext(); ) {
        Element el = (Element) iter.next();
        if(el.getName().equals("to")){
          System.out.println(el.getText());
        }
        }
      }
      catch (IOException ex) {
        ex.printStackTrace();
      }
      catch (JDOMException ex) {
        ex.printStackTrace();
      }
    }

    很簡單把。


    (3)DOM
    document JDOM Document 之間的相互轉換使用方法,簡單!
    DOMBuilder builder = new DOMBuilder();
    org.jdom.Document jdomDocument = builder.build(domDocument);
    // work with the JDOM document…

    DOMOutputter converter = new DOMOutputter();
    org.w3c.dom.Document domDocument = converter.output(jdomDocument);
    // work with the DOM document…

    2.XML
    文檔輸出
    XMLOutPutter
    類:
    JDOM
    的輸出非常靈活 , 支持很多種 io 格式以及風格的輸出
    Document doc = new Document(...);
    XMLOutputter outp = new XMLOutputter();
    // Raw output
    outp.output(doc, fileOutputStream);
    // Compressed output
    outp.setTextTrim(true);
    outp.output(doc, socket.getOutputStream());
    // Pretty output
    outp.setIndent(" ");
    outp.setNewlines(true);
    outp.output(doc, System.out);
    ......
    詳細請參閱最新的 JDOM API 手冊


    3.Element 
    類:
    (1)
    瀏覽 Element
    //
    獲得根元素 element
    Element root = doc.getRootElement();
    // 
    獲得所有子元素的一個 list
    List allChildren = root.getChildren();
    // 
    獲得指定名稱子元素的 list
    List namedChildren = root.getChildren("name");
    //
    獲得指定名稱的第一個子元素
    Element child = root.getChild("name");
    (這里的 List Java.util.List

    JDOM
    給了我們很多很靈活的使用方法來管理子元素
    List allChildren = root.getChildren();
    // 
    刪除第四個子元素
    allChildren.remove(3);
    // 
    刪除叫 “jack” 的子元素
    allChildren.removeAll(root.getChildren("jack"));

    root.removeChildren("jack"); // 
    便捷寫法
    // 
    加入
    allChildren.add(new Element("jane"));

    root.addContent(new Element("jane")); // 
    便捷寫法
    allChildren.add(0, new Element("first"));


    (2)
    移動 Elements:
    JDOM 里很簡單
    Element movable = new Element("movable");
    parent1.addContent(movable); // place
    parent1.removeContent(movable); // remove
    parent2.addContent(movable); // add

    Dom
    Element movable = doc1.createElement("movable");
    parent1.appendChild(movable); // place
    parent1.removeChild(movable); // remove
    parent2.appendChild(movable); // 
    出錯 !

    補充:
    糾錯性
    JDOM
    Element 構造函數(以及它的其他函數)會檢查 element 是否合法。
    而它的 add/remove 方法會檢查樹結構,檢查內容如下:
    1.
    在任何樹中是否有回環節點
    2.
    是否只有一個根節點
    3.
    是否有一致的命名空間( Namespaces



    (3)Element
    text 內容讀取
    <description>
    A cool demo
    </description>

    // The text is directly available
    // Returns "\n A cool demo\n"
    String desc = element.getText();

    // There's a convenient shortcut
    // Returns "A cool demo"
    String desc = element.getTextTrim();

    (4)Elment
    內容修改
    element.setText("A new description");
    3.
    可正確解釋特殊字符
    element.setText("<xml> content");
    4.CDATA
    的數據寫入、讀出
    element.addContent(new CDATA("<xml> content"));
    String noDifference = element.getText();

    混合內容
    element
    可能包含很多種內容,比如說

    <table>
    <!-- Some comment -->
    Some text
    <tr>Some child element</tr>
    </table>

    table 的子元素 tr
    String text = table.getTextTrim();
    Element tr = table.getChild("tr");

    也可使用另外一個比較簡單的方法
    List mixedCo = table.getContent();
    Iterator itr = mixedCo.iterator();
    while (itr.hasNext()) {
    Object o = i.next();
    if (o instanceof Comment) {
    ...
    }
    // 
    這里可以寫成 Comment, Element, Text, CDATA,ProcessingInstruction,  或者是 EntityRef 的類型
    }
    // 
    現在移除 Comment, 注意這里游標應為 1 。這是由于回車鍵也被解析成 Text 類的緣故 , 所以 Comment 項應為 1 。
    mixedCo.remove(1);



    4.Attribute

    <table width="100%" border="0"> </table>
    //
    獲得 attribute
    String width = table.getAttributeValue("width");
    int border = table.getAttribute("width").getIntValue();
    //
    設置 attribute
    table.setAttribute("vspace", "0");
    // 
    刪除一個或全部 attribute
    table.removeAttribute("vspace");
    table.getAttributes().clear();



    5.
    處理指令 (Processing Instructions) 操作
    一個 Pls 的例子
    <?br?>
    <?cocoon-process type="xslt"?>
          |     |
          |     |
        
    目標     數據

    處理目標名稱 (Target)
    String target = pi.getTarget();
    獲得所有數據( data ),在目標( target )以后的所有數據都會被返回。
    String data = pi.getData();
    獲得指定屬性的數據
    String type = pi.getValue("type");
    獲得所有屬性的名稱
    List ls = pi.getNames();

    6.
    命名空間操作
    <xhtml:html 
    xmlns:xhtml="http://www.w3.org/1999/xhtml">
    <xhtml:title>Home Page</xhtml:title>
    </xhtml:html>

    Namespace xhtml = Namespace.getNamespace("xhtml", "http://www.w3.org/1999/xhtml");
    List kids = html.getChildren("title", xhtml);
    Element kid = html.getChild("title", xhtml);
    kid.addContent(new Element("table", xhtml));

    7.XSLT
    格式轉換
    使用以下函數可對 XSLT 轉換
    最后如果你需要使用 w3c Document 則需要轉換一下。
    public static Document transform(String stylesheet
    , Document in)
                              throws JDOMException {
      try {
        Transformer transformer = TransformerFactory.newInstance()
                      .newTransformer(new StreamSource(stylesheet));
        JDOMResult out = new JDOMResult();
        transformer.transform(new JDOMSource(in), out);
        return out.getDeocument();
      }
      catch (TransformerException e) {
        throw new JDOMException("XSLT Trandformation failed", e);
      }
      }

    參考書目:

    1.JDOM
    官方網站:  http://www.jdom.org

    2.<<Processing XML with Java>> Elliotte Rusty Harold 2002

    3.JDOM API Documentation

    4.<<JDOM Makes XML Easy>>Jason Hunter Co-Creator JDOM Project

    5.WSDP Tutorial

    posted on 2006-09-14 11:09 周銳 閱讀(176) 評論(0)  編輯  收藏 所屬分類: Java
    主站蜘蛛池模板: 成人爽A毛片免费看| 日韩精品免费电影| 亚洲精品天堂在线观看| 国产免费观看网站| 免费成人在线视频观看| 亚洲永久在线观看| 亚洲国产精品人人做人人爱| 久久永久免费人妻精品下载| 亚洲精品V天堂中文字幕| 国产亚洲美女精品久久久2020| 16女性下面扒开无遮挡免费| 色视频在线观看免费| 日本久久久久亚洲中字幕| 免费看国产一级片| 国产成人免费在线| 国产福利免费视频 | 日韩视频在线精品视频免费观看 | 91在线免费视频| 亚洲精品无码久久久久APP| 亚洲av永久无码精品漫画| 精品免费久久久久久成人影院| 日本免费中文视频| 国产亚洲综合久久| 亚洲中文字幕无码av在线| 亚洲中文久久精品无码| 四虎在线免费播放| 16女性下面扒开无遮挡免费| 精品无码一级毛片免费视频观看| 中文字幕亚洲码在线| 亚洲五月激情综合图片区| 亚洲国产综合精品中文字幕| 思思re热免费精品视频66| 男女午夜24式免费视频| 夜夜爽妓女8888视频免费观看| 亚洲欧美日韩中文字幕一区二区三区| 国产亚洲精品无码成人| 亚洲国产精品自在拍在线播放| 97视频热人人精品免费| 一区二区在线免费观看| 国产日韩AV免费无码一区二区| 全部在线播放免费毛片|