posts - 20,  comments - 7,  trackbacks - 0

          All about JAXP

          http://www-128.ibm.com/developerworks/java/library/x-jaxp

          Brett McLaughlin

          ?

          Document Object Model (DOM)

          Simple API for XML (SAX)

          ?

          JDK1.4

          javax.xml.parsers
          javax.xml.transform
          javax.xml.transform.dom
          javax.xml.transform.sax
          javax.xml.transform.stream

          ?

          JDK5.0

          javax.xml
          javax.xml.datatype
          javax.xml.namespace
          javax.xml.parsers
          javax.xml.transform
          javax.xml.transform.dom
          javax.xml.transform.sax
          javax.xml.transform.stream
          javax.xml.validation
          javax.xml.xpath

          ?

          ?

          嚴格來說, JAXP 并沒有提供新的解析 XML 的方法,但是它使得我們更容易地使用 DOM 或者 SAX 來進行解析任務(wù),更能以一種 vendor-neutral 的方式來使用 DOM SAX 。

          ?

          JAXP SAX, DOM, JDOM dom4j (這四個都可以解析 XML )沒有可比較性,它并沒有提供一個新的解析 XML 的方法。

          ?

          JAXP API, located in the javax.xml.parsers package. All of these classes sit on top of an existing parser. 其中的 6 個類都是建立在已有的解析上面的。

          ?

          JDOM dom4j 都提供不同的模型來接受來自 SAX/DOM 的數(shù)據(jù),他們從內(nèi)部來講都是使用了 SAX ,不過是做了些修改。

          ?

          此外, Java 1.5 Xerces 的包 org.apache.xerces 被放到了 com.sun.org.apache.xerces.internal

          ?

          First, com.sun.xml.tree.XMLDocument class is not part of JAXP. It is part of Sun's Crimson parser, packaged in earlier versions of JAXP.

          ?

          Second, a major purpose of JAXP is to provide vendor independence when dealing with parsers. With JAXP, you can use the same code with Sun's XML parser, Apache's Xerces XML parser, and Oracle's XML parser.

          ?

          先從 SAX 說起,我們只用繼承 DefaultHandler (org.xml.sax.helpers 包中 ) 就能獲得所有的 callbacks ,只用在需要的方法中加入實現(xiàn)的代碼。

          ?

          Here's the typical SAX routine:

          1 Create a SAXParser instance using a specific vendor's parser implementation.

          2 Register callback implementations (by using a class that extends DefaultHandler, for example).

          3 Start parsing and sit back as your callback implementations are fired off.

          ?

          SAX 必須 指定 XML 驅(qū)動(如 org.apache.xerces.parsers.SAXParser ),而 JAXP 提供了更好的選擇,只要我們提供什么 XML 驅(qū)動(在 classpath 中配置),它就調(diào)用什么驅(qū)動,不需要改動代碼。

          ? ?

          new SAXParserFactory.newSAXParser() 就返回 JAXP SAXParser 類,這個類包裝了 SAX parser (an instance of the SAX class org.xml.sax.XMLReader ) 。

          ?

          In Listing 1, you can see that two JAXP-specific problems can occur in using the factory: the inability to obtain or configure a SAX factory, and the inability to configure a SAX parser.

          The first of these problems, represented by a FactoryConfigurationError, usually occurs when the parser specified in a JAXP implementation or system property cannot be obtained.

          The second problem, represented by a ParserConfigurationException, occurs when a requested feature is not available in the parser being used. Both are easy to deal with and shouldn't pose any difficulty when using JAXP.

          ?

          SAXParser parse 方法可以接受 SAX InputSource , Java InputStream 或者 URL in String form

          ?

          可以通過 SAXParser getXMLReader() 方法來獲得底層的 SAX parser org.xml.sax.XMLReader 的實例),這樣就可以使用各個 SAXParser 方法。 [ 參照 Listing2]

          ?? ?

          ?

          使用 DOM??

          The only difference between DOM and SAX in this respect is that with DOM you substitute DocumentBuilderFactory for SAXParserFactory, and DocumentBuilder for SAXParser.

          ?

          The major difference is that variations of the parse() method do not take an instance of the SAX DefaultHandler class. Instead they return a DOM Document instance representing the XML document that was parsed. The only other difference is that two methods are provided for SAX-like functionality:

          • setErrorHandler(), which takes a SAX ErrorHandler implementation to handle problems that might arise in parsing
          • setEntityResolver(), which takes a SAX EntityResolver implementation to handle entity resolution

          JAXP 的使用

          1. Source for input

          The javax.xml.transform.Source interface is the basis for all input into JAXP and the transformation API. This interface defines only two methods -- getSystemId() and setSystemId(String systemId) .

          ?

          ?

          JAXP 提供了三個實現(xiàn) Source 接口的類:

          • javax.xml.transform.dom.DOMSource passes a DOM Node (and its children) into JAXP.
          • javax.xml.transform.sax.SAXSource passes the results of SAX callbacks (from an XMLReader ) into JAXP.
          • javax.xml.transform.stream.StreamSource passes XML wrapped in a File , InputStream , or Reader into JAXP.? ?

          2. Result for output

          ? javax.xml.transform.Result 也有兩個方法: getSystemId() setSystemId(String systemId) 。 同樣有三個實現(xiàn)類:

          • javax.xml.transform.dom.DOMResult passes transformed content into a DOM Node .
          • javax.xml.transform.sax.SAXResult passes the results of a transformation to a SAX ContentHandler .
          • javax.xml.transform.stream.StreamResult passes the transformed *ML into a File , OutputStream , or Writer .

          3. Performing transformations with JAXP

          1)Getting a Factory? ???

          2)Creating a Transformer? ?
          3)Performing the transformation?? ?
          4)Caching XSL stylesheets

          JAXP this way has two significant limitations:

          • The Transformer object processes the XSL stylesheet each and every time transform() is executed.
          • Instances of Transformer are not thread-safe. You can't use the same instances across multiple threads.

          Transformer 實例不是線程安全的,不能通過多線程去使用同一個 Transformer 實例。

          5)Loading a Template

          javax.xml.transform.Templates .

          ?

          The Templates interface is thread-safe (addressing the second limitation) and represents a compiled stylesheet (addressing the first limitation).

          Templates 實例是線程安全的,可以處理一堆 XSL ,解決了上述兩個限制。

          6)From Transformer to Templates

          如果只要對一個 stylesheet 進行一個 transformation ,那么用 Transformer 比較快,沒有必要選擇 Templates 對象。但是考慮到線程安全問題,還是推薦使用 Templates 。

          7)Changing the XSL processor

          JAXP 默認使用 Xalan-J ,如果要使用其它 parser ,可以通過 javax.xml.transform.TransformerFactory 修改。


          java -D javax.xml.transform.TransformerFactory=[transformer.impl.class] TestTransformations?
          simple.xml simple.xsl

          ?

          posted on 2006-09-08 13:15 Lizzie 閱讀(551) 評論(1)  編輯  收藏 所屬分類: 專業(yè)積木

          FeedBack:
          # re: All about JAXP閱讀筆記
          2007-08-12 17:16 | dreamstone
          寫的不錯  回復(fù)  更多評論
            

          <2007年8月>
          2930311234
          567891011
          12131415161718
          19202122232425
          2627282930311
          2345678

          常用鏈接

          留言簿(1)

          隨筆分類

          隨筆檔案

          文章分類

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 鄂托克前旗| 定兴县| 从江县| 嘉善县| 兴国县| 琼海市| 绥滨县| 天等县| 正宁县| 阜阳市| 江西省| 上林县| 府谷县| 太白县| 墨竹工卡县| 元江| 清镇市| 玉田县| 和田市| 镇远县| 玉林市| 上犹县| 化德县| 北宁市| 张家川| 兴义市| 盐城市| 苗栗市| 扎囊县| 神农架林区| 万荣县| 武胜县| 南陵县| 萨嘎县| 闸北区| 鄱阳县| 静海县| 平度市| 梁平县| 定安县| 布拖县|