My Blog JAVA

          My Blog JAVA

          導航

          <2025年7月>
          293012345
          6789101112
          13141516171819
          20212223242526
          272829303112
          3456789

          統計

          常用鏈接

          留言簿(4)

          隨筆檔案

          文章檔案

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          2006年10月19日 #

          Apache Cocoon入門

          在某種意義上,可將Cocoon視為一個基于XML的內容管理系統,因其提供了一種機制來描述Web信息項目(內容)的結構和語義、這些項目的關系、它們如何隨著時間的推移而發生改變(邏輯)以及在請求時如何向用戶呈現(它們的樣式)。事實上,Cocoon項目作為Apache Web服務器項目的一部分,它的作用之一就是組織和控制Apache麾下眾多項目的文檔化過程。

          作為對其真實用途的一個比喻,Cocoon(繭)這個名字具有深遠的意義。它代表一種包裹結構,其中的某些東西將從幼蟲階段成長為美麗的蝴蝶,并準備展翅飛翔。但在Apache Cocoon的主頁上,沒有對這個巧妙的比喻進行說明。相反,它只是對這個項目進行了準確的技術性解釋:“Apache Cocoon是一個XML發布框架,它將XML和XSLT技術在服務器應用程序中的應用提升到一個新級別。Cocoon的宗旨是提升管道化SAX處理的性能和擴展性,通過對內容、邏輯和樣式的分離來營造一個靈活的環境。”

          到底什么是Cocoon?

          Cocoon最初的型態是一個簡單的Java servlet,全部使用標準W3C組件:用文檔對象模型(DOM)來解析文檔,用XML來捕捉和格式化數據,用XSLT來轉換數據和合并/操縱XML文檔,并用XSL來管理文檔的表示以便通過Web傳送。但人們很快就要求它為其他類型的內容提供服務(比如程序和文檔),所以Cocoon逐漸發展成為一個完整的、基于XML的發布框架及系統。

          隨著時間的推移,幾個新的XML組件問世了,比如SAX。另外,XSL也逐漸細分為幾個不同的組件,分別提供Transforms、Formatting Objects和XPath功能。這些新標準直接促成了Cocoon 2在2002年的問世,它定義了一個標準的(而且仍在發展的)內容管理系統,并面向公眾開放。

          就目前來說,我們可采取幾種不同的方式來描述Cocoon:一個XML發布框架,一個數據源聚合器以及一系列管道和組件的集合。

          作為發布框架的Cocoon

          Cocoon基于對SAX事件的管道式處理。Web應用程序如果圍繞這個框架來構建,將獲得較好的擴展性和性能。利用一個集中式的配置系統,你可以方便地創建、部署和維護Web應用程序。Cocoon使用了一個緩存系統,所有組件都可根據需要進行動態配置。接收到用戶請求后,會自動檢查緩存,判斷請求的URI(統一資源標識符)是否存在。如果存在,就直接傳遞緩存的內容,不需要通過一個管道來處理它。

          Cocoon作為數據源聚合器

          Cocoon可作為一個抽象的引擎使用(通過一個Java servlet),它基于自定義的協議處理程序,能通過標準URI來訪問外部數據源。Cocoon甚至能遞歸調用自身,使數據流能在多個管道化階段同時處理,從而提高處理速度和效率。

          管道和組件

          Cocoon體系結構的核心設計思想是模塊化和抽象處理。Cocoon管道在概念上和UNIX系統中使用的管道差不多,只是Cocoon管道中的所有元素都是通過解析XML文檔而創建的SAX事件。Cocoon識別3種類型的管道元素(組件),分別是生成器(generators)、轉換器(transformers)和序列化器(serializers)。其中,生成器使用一個請求的URI來生成SAX事件;轉換器使用SAX事件并生成其他SAX事件;序列化器使用SAX事件并生成一些響應。

          Cocoon的用途

          簡單地說,Cocoon管道用于生成和遞送內容。內容采用的是某種可識別的形式,由一個生成器和一個序列化器構成。在較典型的Cocoon管道中,生成器之后可能緊接著一個或多個轉換器鏈,而序列化器用于生成不同格式的輸出。采取這種方式,同一個源文檔可為Web瀏覽器生成HTML格式的內容,為WAP設備生成WML格式的內容,為打印輸出生成PDF格式的內容。

          作為一個開發平臺,Cocoon最吸引人的地方在于它提供了品種豐富的生成器、轉換器和序列化器。人們為Cocoon 2項目開發和捐贈了許多這樣的組件。一經捐贈,這些組件就可進行定制,以添加新功能或者進行擴展,從而創建出新的組件。A總結了適用于Cocoon的一些常用生成器、轉換器和序列化器。

          表A

          類別名稱說明
          生成器DirectoryGenerator將目錄列表轉換成XML格式,以便從中生成SAX事件
          生成器FileGenerator解析一個文件或URI,并生成SAX事件
          生成器JSPGenerator根據JSP頁來生成XML和SAX事件
          生成器ServerPagesGenerator根據XSP頁來生成XML和SAX
          轉換器i18nTransformer使用i18n字典和語言參數值來轉換SAX事件
          轉換器XincludeTransformer通過為現有的SAX流添加SAX事件,從而處理xinclude命名空間,并包括外部源
          轉換器XSLTransformer根據XSLT樣式表定義來轉換SAX事件流
          序列化器HTMLSerializer根據SAX事件來生成HTML響應
          序列化器PDFSerializer根據SAX事件,使用Apache FOP(格式輸出處理器)來生成PDF
          序列化器SVG2JPGSerializer根據SVG SAX事件,使用Apache Batik來生成JPEG圖像
          序列化器TextSerializer根據SAX事件來生成純文本輸出,適用于非XML文本,比如CSS或程序語言代碼
          序列化器XMLSerializer根據SAX事件來生成XML響應
          可由Cocoon使用的部分組件

          如所你見,Cocoon的功能并非只是簡單地將數據格式化成HTML。在未來的文章中,我們將研究如何在Cocoon環境中創建和處理文檔,并更詳細地介紹在這個環境中工作所牽涉的問題。就目前來說,你只需理解Cocoon是針對多種目的來捕捉、呈現和遞送Web內容的一種方式。

          posted @ 2006-10-19 12:23 My JAVA Blog 閱讀(1939) | 評論 (2)編輯 收藏

          2006年9月23日 #

          Apt 使用備忘

          命令?????????????????????????????????????????????????????????????? 作用
          ----------------------------------------------------------------------------------------------------------------------------------------
          sudo apt-cache search package???????????????? 搜索包
          ----------------------------------------------------------------------------------------------------------------------------------------
          sudo apt-cache show package?????????????????? 獲取包的相關信息,如說明、大小、版本等
          ----------------------------------------------------------------------------------------------------------------------------------------
          sudo apt-get install package????????????????????? 安裝包
          ----------------------------------------------------------------------------------------------------------------------------------------
          sudo apt-get install package - - reinstall??? 重新安裝包
          ----------------------------------------------------------------------------------------------------------------------------------------
          sudo apt-get remove package?????????????????? 刪除包
          ----------------------------------------------------------------------------------------------------------------------------------------
          sudo apt-get remove package - - purge??? 刪除包,包括刪除配置文件等
          ----------------------------------------------------------------------------------------------------------------------------------------
          sudo apt-get update?????????????????????????????????? 更新源
          ----------------------------------------------------------------------------------------------------------------------------------------
          sudo apt-get dist-upgrade????????????????????????? 升級系統
          ----------------------------------------------------------------------------------------------------------------------------------------
          sudo apt-get -f install????????????????????????????????? 強制安裝
          ----------------------------------------------------------------------------------------------------------------------------------------
          sudo apt-cache depends package???????????? 了解使用依賴
          ----------------------------------------------------------------------------------------------------------------------------------------
          sudo apt-cache rdepends package??????????? 了解某個具體的依賴
          ----------------------------------------------------------------------------------------------------------------------------------------
          sudo apt-get build-dep package???????????????? 安裝相關的編譯環境
          ----------------------------------------------------------------------------------------------------------------------------------------

          posted @ 2006-09-23 01:09 My JAVA Blog| 編輯 收藏

          2006年9月22日 #

          用XML和XSL來生成動態頁面

          XML(可擴展標記語言)看起來可能像某種W3C標準——現在沒有什么實際影響,即使以后能派上用場,也是很久以后的事。但實際上,它現在已經得到了應用。所以,不要等到XML已被加進了你最喜愛的HTML編輯器中才開始使用它。它現在就可以解決各種內部問題和B2B系統問題。

          在Sparks.com,我們使用XML來標準化從Java對象到HTML數據顯示等不同系統之間的數據表示。

          特別需要指出的是,我們發現,只要以非常基本的XML結構來實現標準化,就可以更容易地共享和操作數據。在這一過程中,我們發現了使用XML的很多有效方法。下面詳細介紹我們現在的應用情況。

          標準化
          在使用XML之前,建立與你要使用的信息不同的XML數據格式。

          生成動態XML
          從數據庫中生成HTML并不新鮮,但生成XML卻很新鮮。這里我們介紹具體的生成步驟。

          用XSL作為模板語言
          XSL(可擴展樣式表語言)是定義XML數據顯示格式的好方法,如果寫成幾個靜態模板會更有效。

          生成HTML
          XML加上XSL就等于HTML。這聽起來似乎不對,但用戶所見的我們的HTML頁面其實就是XML和XSL共同產生的效果。


          一、標準化

          XML的能力來自于它的靈活性。但不幸的是,它有時太靈活了,以至于你會面對一個空白的頁面,發愁該怎么解決問題。

          在任何XML的項目中,第一步工作都是創建標準的數據格式。為此你要作出以下決定:

          &#8226; 要涉及哪些數據
          &#8226; 是否要使用DTD(文件類型定義)
          &#8226; 是否要使用DOM(文檔對象模型)或SAX(XML的簡化API)解析

          確定數據:
          因為沒有標準的XML格式,開發者可以自由地開發自己的格式。然而,如果你的格式只能被一個應用程序識別,那么你只能運行這個程序來使用該格式。如果還有其他程序也能讀懂你的XML格式,那顯然會更有幫助。如果某個XML格式被修改,則使用它的系統可能也需要被修改,所以你應該建立盡可能完整的格式。因為大多數系統忽略它們無法識別的標簽,所以改變一個XML格式的最安全的方法是添加標簽,而不是修改標簽。

          單擊此處查看XML數據格式實例

          在Sparks.com,我們查看了不同的產品展示需要的所有產品數據。盡管并不是所有的頁面都使用全部數據,但我們還是由此開發出適用于所有數據的非常完整的XML數據格式。例如,我們的產品明細信息頁面顯示的數據要比產品瀏覽頁面多。然而,我們在這兩種情況下仍然使用相同的數據格式,因為每個頁面的XSL模板都只使用它所需要的字段。

          是否使用DTD
          在Sparks.com,我們使用組織良好的XML,而不使用僅僅是正確的XML,因為前者不需要DTD。DTD在用戶點擊和看到頁面之間加入了一個處理層。我們發現這一層需要太多的處理。當然,在以XML格式與其他公司通信時,使用DTD還是很不錯的。因為DTD能在發送和接受時能保證數據結構正確。

          選擇解析引擎
          現在,可以使用的解析引擎有好幾個。選擇哪一個幾乎完全取決于你的應用需要。如果你決定使用DTD,那么這個解析引擎必須能使你的XML被DTD驗證。你可以將驗證另放到一個進程中,但那樣會影響性能。

          SAX和DOM是兩個基本的解析模型。SAX基于事件,所以在XML被解析時,事件被發送給引擎。接下來,事件與輸出文件同步。DOM解析引擎為動態XML數據和XSL樣式表建立層次樹狀結構。通過隨機訪問DOM樹,可以提供XML數據,就象由XSL樣式表來決定一樣。SAX模型上的爭論主要集中于對DOM結構的內存降低過度和加快XSL樣式表解析時間縮短方面。

          然而,我們發現使用SAX的很多系統并沒有充分發揮它的能力。這些系統用它來建立DOM結構并通過DOM結構來發送事件。用這種方法,在任何XML處理之前必須從樣式表中建立DOM,所以性能會下降。

          二、生成動態XML

          一旦建立了XML格式,我們需要一種能夠將其從數據庫中動態移植的方法。

          生成XML文檔相對來說比較簡單,因為它只需要一個可以處理字符串的系統。我們建立了一個使用Java Servlet、Enterprise JavaBean server、JDBC和RDBMS(關系型數據庫管理系統)的系統。

          &#8226; Servlet通過把生成XML文檔的任務交給Enterprise JavaBean (EJB)來處理產品信息請求。
          &#8226; EJB使用JDBC從數據庫里查詢所需的產品詳細信息。
          &#8226; EJB生成XML文件并把它傳遞給Servlet。
          &#8226; Servlet調用解析引擎,從XML文件和靜態的XSL樣式表中創建HTML輸出。

          (有關XSL應用的其他信息,請參閱用XSL作為模板語言。)

          生成XML的例子
          在Java中創建XML文檔字符串的真正代碼可以分成幾個方法和類。

          啟動XML生成過程的代碼放在EJB方法里。這一實例會立即創建一個StringBuffer,以便存儲生成的XML字符串。

          StringBuffer xml = new StringBuffer();
          xml.append(XmlUtils.beginDocument("/browse_find/browse.xsl", "browse", request));
          xml.append(product.toXml());
          xml.append(XmlUtils.endDocument("browse");
          out.print(xml.toString());


          后面的三個xml.append()變元本身就是對其他方法的調用。
          產生文件頭
          第一個附加方法調用XmlUtils類來產生XML文件頭。我們的Java Servlet中的代碼如下:

          public static String beginDocument(String stylesheet, String page)
          {
          ? ? StringBuffer xml = new StringBuffer();
          ? ? xml.append("<?xml version=\"1.0\"?>\n")
          ? ? .append("<?xml-stylesheet href=\"")
          ? ? .append(stylesheet).append("\"")
          ? ? .append(" type =\"text/xsl\"?>\n");
          ? xml.append("<").append(page).append(">\n");
          ? return xml.toString();
          }

          這段代碼生成了XML文件頭。<?xml>標簽把本文件定義為支持1.0版本的XML文件。第二行代碼指向用以顯示數據的正確樣式表的位置。最后包括進去的是項級標簽(本實例中為<browse>)。在文件末尾,只有<browse>標簽需要被關閉。

          <?xml version="1.0"?> <?xml-stylesheet href="/browse_find/browse.xsl" type="text/xsl"?> <browse>

          填入產品信息
          完成了文件頭后,控制方法會調用Java對象來產生它的XML。本例中調用的是product對象。product對象使用兩個方法來產生它的XML表示。第一個方法toXML()通過產生<product>和</product>標簽來建立product節點。然后它會調用internalXML(),這樣就能提供產品XML所需的內容。internalXML()是一系列的StringBuffer.append()調用。StringBuffer也被轉換成字符串并返回給控制方法。
          public String toXml()
          ? ? {
          ? ? StringBuffer xml = new StringBuffer("<product>\n");
          ? ? xml.append(internalXml());
          ? ? xml.append("</product>\n");
          ? ? return xml.toString();
          ? ? }

          public String internalXml()
          ? ? {
          ? ? StringBuffer xml = new
          ? ? StringBuffer("\t")
          ? ? ? ? .append(productType).append("\n");
          ? ? xml.append("\t").append(idValue.trim())
          ? ? ? ? .append("\n");
          ? ? xml.append("\t").append(idName.trim())
          ? ? ? ? .append("\n");
          ? ? xml.append("\t").append(page.trim())
          ? ? ? ? .append("\n");
          厖?
          ? ? ? xml.append("\t").append(amount).append("\n");
          ? ? xml.append("\t").append(vendor).append("\n");
          ? ? xml.append("\t\n");
          ? ? xml.append("\t").append(pubDesc).append("\n");
          ? ? xml.append("\t").append(venDesc).append("\n";
          厖?
          ? ? return xml.toString();
          }


          關閉文件
          最后,XMLUtils.endDocument()方法被調用。這個調用關閉XML標簽(本例中為),并最終完成架構好的XML文件。來自控制方法的整個StringBuffer也轉換成字符串,并返回給處理最初HTTP請求的servlet。

          三、用XSL作為模板語言

          為了得到HTML輸出,我們把生成的XML文件和控制XML數據如何表示的XSL模板相結合。我們的XSL模板由精心組織的XSL和HTML標簽組成。

          開始建模板
          我們的XSL模板開始部分與下面這段代碼類似。第一行代碼為必需代碼,將本文件定義為XSL樣式表。xmlns:xsl=屬性引用本文件所使用的XML名稱空間,而version=屬性則定義名稱空間的版本號。在文件的末尾,我們關閉標簽。

          由<xsl:template>開始的第二行代碼確定了XSL模板的模式。Match屬性是必需的,在這里指向XML標簽<basketPage>。在我們的系統里,<basketPage>標簽里包含<product> 標簽,這使得XSL模板可以訪問嵌在<product>標簽內的產品信息。我們又一次必須在文件末尾關閉<xsl:template>標簽。

          接下來,我們來看一看組織良好的HTML。由于它將被XML解析引擎處理,所以必須符合組織良好的XML的所有規則。從本質上來講,這意味著所有的開始標簽必須有對應的結束標簽。例如,通常不被結束的<P>標簽,必須用</P>關閉。


          <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
          version="1.0">
          <xsl:template match="basketPage">
          <html>
          <head>
          <title>Shopping Bag / Adjust Quantity</title>
          </head>
          <body bgcolor="#cccc99" bgproperties="fixed" link="#990000" vlink="#990000">
          <br>
          ?br> </xsl:template>
          </xsl:stylesheet>


          在模板的主體內,有很多XSL標簽被用于為數據表示提供邏輯。下面解釋兩個常用的標簽。
          Choose
          <xsl:choose>標簽類似于傳統編程語言中if-then-else結構的開始部分。在XSL中,choose標簽表示在代碼進入的部分中,賦值將觸發動作的發生。擁有賦值屬性的<xsl:when>標簽跟在choose標簽后面。如果賦值是正確的,位于<xsl:when>的開始和結束標簽之間的內容將被使用。如果賦值錯誤,就使用<xsl:otherwise>的開始和結束標簽之間的內容。整個部分用</xsl:choose>來結束。

          在這個例子里,when標簽會為quantity標簽檢查XML。如果quantity標簽里含有值為真的error屬性,quantity標簽將會顯示列在下面的表格單元。如果屬性的值不為真,XSL將會顯示otherwise標簽間的內容。在下面的實例里,如果error屬性不真,則什么都不會被顯示。

          <xsl:choose>
          <xsl:when test="quantity[@error='true']">
          <td bgcolor="#ffffff"><img height="1" width="1" src="http://img.sparks.com/Images/I-Catalog/sparks_images/sparks_ui/clearpixel.gif"/></td>
          <td valign="top" bgcolor="#ffffff" colspan="2"><font face="Verdana, Arial" size="1" color="#cc3300"><b>*Not enough in stock. Your quantity was adjusted accordingly.</b></font></td>
          </xsl:when>
          <xsl:otherwise>
          </xsl:otherwise>
          </xsl:choose>


          For-each
          <xsl:for-each>標簽可以用來對相似XML數據的多種情況應用同一個樣式表。對于我們來說,可以從數據庫中取出一系列產品信息,并在Web頁上進行統一格式化。這里有一個例子:
          <xsl:for-each select="package">
          <xsl:apply-templates select="product"/>
          </xsl:for-each>


          for-each 循環在程序遇到標簽時開始。這個循環將在程序遇到標簽時結束。一旦這個循環運行,每次標簽出現時都會應用這個模板。

          四、生成HTML

          將來的某一時刻,瀏覽器將會集成XML解析引擎。到那時,你可以直接向瀏覽器發送XML和XSL文件,而瀏覽器則根據樣式表中列出的規則顯示XML數據。不過,在此之前開發者們將不得不在他們服務器端的系統里創建解析功能。

          在Sparks.com,我們已經在Java servlet里集成了一個XML解析器。這個解析器使用一種稱為XSLT (XSL Transformation)的機制,按XSL標簽的說明向XSL模板中添加XML數據。

          當我們的Java servlet處理HTTP請求時,servlet檢索動態生成的XML,然后XML被傳給解析引擎。根據XML文件中的指令,解析引擎查找適當的XSL樣式表。解析器通過DOM結構創建HTML文件,然后這個文件再傳送給發出HTTP請求的用戶。

          如果你選擇使用SAX模型,解析器會通讀XML源程序,為每個XML標簽創建一個事件。事件與XML數據對應,并最終按XSL標簽向樣式表中插入數據。

          posted @ 2006-09-22 12:16 My JAVA Blog| 編輯 收藏

          2006年9月20日 #

          修改源并升級更新ubuntu

          http://wiki.ubuntu.org.cn/%E5%BF%AB%E9%80%9F%E8%AE%BE%E7%BD%AE%E6%8C%87%E5%8D%97/DapperDrake

          posted @ 2006-09-20 21:50 My JAVA Blog| 編輯 收藏

          僅列出標題  
          主站蜘蛛池模板: 金乡县| 余江县| 姜堰市| 吉安市| 武平县| 宁波市| 内丘县| 沂源县| 延长县| 绥中县| 武汉市| 勐海县| 正镶白旗| 德保县| 札达县| 延吉市| 常熟市| 常德市| 田阳县| 莱芜市| 瓮安县| 美姑县| 蓝山县| 新邵县| 颍上县| 阿鲁科尔沁旗| 西林县| 来安县| 烟台市| 淳化县| 盐池县| 临泉县| 聂荣县| 静安区| 绥阳县| 阿坝| 磐石市| 雷波县| 西乡县| 高邑县| 阿城市|