明輝手游網(wǎng)中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

XML在B/S架構(gòu)開發(fā)中的應用

[摘要]傳統(tǒng)上, 我們利用JSP+Bean來開發(fā)用戶界面, 這里介紹一種利用XML+XSLT的方法來替代JSP  動機:  1. JSP構(gòu)造頁面太痛苦. 代碼嵌入頁面導致頁面臃腫, 邏輯復雜, 不易編輯.  2. 程序員和美工的接口必須精確定義. 復雜的嵌套輸出必須構(gòu)造復雜的顯示類作為接口.  3. 調(diào)試...
傳統(tǒng)上, 我們利用JSP+Bean來開發(fā)用戶界面, 這里介紹一種利用XML+XSLT的方法來替代JSP

  
動機:

  1. JSP構(gòu)造頁面太痛苦. 代碼嵌入頁面導致頁面臃腫, 邏輯復雜, 不易編輯.
  2. 程序員和美工的接口必須精確定義. 復雜的嵌套輸出必須構(gòu)造復雜的顯示類作為接口.
  3. 調(diào)試JSP必須等到前端程序結(jié)束才能看到效果.
  4. 調(diào)試JSP效率極低, 一點點小的修改都會引起jsp的重新編譯.

  新的XML的解決方案:

  1. 一個servlet做統(tǒng)一管理. 接受url請求, 映射到對應的程序bean.
  2. 程序bean只產(chǎn)生XML, 由servlet統(tǒng)一用對應的XSL轉(zhuǎn)換為html.

  好處:

  1. JDK1.4已經(jīng)自帶XML API和XSLT, 并且支持XSLT 1.0標準. IE6也支持同樣標準.
  2. 開發(fā)前先制作接口用的demo XML, 程序員的輸出必須符合此格式. 美工根據(jù)此格式制作XSL. 接口可視化, 明確定義.
  3. 只要定義好接口XML, 兩邊幾乎不需要再聯(lián)合調(diào)試. 美工利用接口XML和IE6就可以直接看到效果.
  4. 程序員只要保證輸出的XML的是否符合接口, 直觀的做文字性對比.
  5. 大量頁面可重用的部分能方便的抽象出來, 在XSL文件中include/import進來. 高度重用, 標準化.
  6. 寫XSL可大量采用template, 結(jié)構(gòu)清晰, 修改方便, 寫頁面變成搭積木, 不再有jsp的層層嵌套.
  7. 對于不同的終端設備, 可以定制不同的XSL, 很方便的就能夠支持手機, pda...
  8. 在程序中利用支持XML的工具, 比如sql2000, 可以直接生成XML結(jié)果, 無需復雜編程.

  
壞處:

  1. 因為要進行XSLT轉(zhuǎn)換, 服務器工作量稍微增大.

  以下是幾個關鍵環(huán)節(jié)的簡單示例:

==============servlet中的XML轉(zhuǎn)換==========
/**
* XML是String
* XSL從文件中讀取
* 直接寫入response
*/
//import javax.xml.transform.*;
//import javax.xml.transform.stream.*;

StreamSource xml = new StreamSource(new StringReader(xmlSource));
StreamSource xsl = new StreamSource(xslFileName);

response.setContentType("text/html; charset=UTF-8");
StreamResult result = new StreamResult(response.getWriter());

Transformer trans = TransformerFactory.newInstance().newTransformer(xsl);
trans.setOutputProperty("encoding","UTF-8");
trans.transform(xml, result);

==================接口XML文件樣本=============
<?xml version="1.0" encoding="UTF-8"?>
<?xml:stylesheet type="text/xsl" href="xxx.xsl"?>
<PAGE>
<OUTPUT>
<INFO>推廣UNICODE, 解決多語言問題.</INFO>
</OUTPUT>
</PAGE>

==================XSL文件樣本=============
<?xml version="1.0" encoding="UTF-8"?>
<?xml:namespace prefix = xsl /><xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:template match="/">

<P align=center>
<xsl:value-of select="page/output/info"></xsl:value-of>

</xsl:template>
</xsl:stylesheet>

  考慮:

  1. 可以把XSLT轉(zhuǎn)換放在IE進行, IE6以下版本要安裝MSXML3, 對客戶端限制太多.
  2. 在客戶端的XSLT轉(zhuǎn)換必須完全讀入XML+XSL, 在網(wǎng)速不高或者內(nèi)容很多的時候反應相當遲鈍.
  3. 手機, pda等設備不能進行XSLT轉(zhuǎn)換, 所以XSLT轉(zhuǎn)換還是放在服務器上比較合適.
  4. 因為一般提交內(nèi)容都比較簡單, 所以沒有采用XML處理, 在程序中也盡量少用XML, 避免影響速度.
  5. 可以在servlet判斷特定參數(shù), 比如發(fā)現(xiàn)有xml-view參數(shù)時, 不做XSLT轉(zhuǎn)換, 直接輸出XML到瀏覽器, 供程序調(diào)試用.

  說明:

  1. 這里只是利用XSLT的功能來解決網(wǎng)站建設中最頭痛的界面和邏輯分開問題, 不是基于XML的內(nèi)容處理.
  2. 如果你想趕時髦, 用XML來全副武裝, 可以參考cocoon2, http://xml.apache.org/cocoon/. 但是請記住, cocoon

  還不完善, 你將碰到亂碼, 速度, 文檔不足的問題, 但是它的思想的確值得學習.
  3. 在tomcat, resin中有用filter實現(xiàn)的xslt轉(zhuǎn)換,可參考。