|
在Sparks.com,我們使用XML來標準化從Java對象到HTML數據顯示等不同系統之間的數據表示。
特別需要指出的是,我們發現,只要以非常基本的XML結構來實現標準化,就可以更容易地共享和操作數據。在這一過程中,我們發現了使用XML的很多有效方法。下面詳細介紹我們現在的應用情況。
標準化
在使用XML之前,建立與你要使用的信息不同的XML數據格式。
生成動態XML
從數據庫中生成HTML并不新鮮,但生成XML卻很新鮮。這里我們介紹具體的生成步驟。
用XSL作為模板語言
XSL(可擴展樣式表語言)是定義XML數據顯示格式的好方法,如果寫成幾個靜態模板會更有效。
生成HTML
XML加上XSL就等于HTML。這聽起來似乎不對,但用戶所見的我們的HTML頁面其實就是XML和XSL共同產生的效果。
一、標準化
XML的能力來自于它的靈活性。但不幸的是,它有時太靈活了,以至于你會面對一個空白的頁面,發愁該怎么解決問題。
在任何XML的項目中,第一步工作都是創建標準的數據格式。為此你要作出以下決定:
&&&
確定數據:
因為沒有標準的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(關系型數據庫管理系統)的系統。
&&&&
(有關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"?> ")
.append("<?xml-stylesheet href="")
.append(stylesheet).append(""")
.append(" type ="text/xsl"?> ");
xml.append("<").append(page).append("> ");
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> ");
xml.append(internalXml());
xml.append("</product> ");
return xml.toString();
}
public String internalXml()
{
StringBuffer xml = new
StringBuffer(" ")
.append(productType).append(" ");
xml.append(" ").append(idValue.trim())
.append(" ");
xml.append(" ").append(idName.trim())
.append(" ");
xml.append(" ").append(page.trim())
.append(" ");
主站蜘蛛池模板: 偷窥wc美女毛茸茸视频 | 伊人国产在线播放 | 精品国产乱码久久久久久下载 | 男女后进式猛烈xx00动态图片 | 99re1久久热在线播放 | 国产乱人精品视频AV麻豆 | 午夜无码片在线观看影院 | 天天靠天天擦天天摸 | 伊人亚洲综合青草青草久热 | 国语自产拍在线视频普通话 | 欧美美女一区二区三区 | 亚洲欧美一区二区三区导航 | 99热最新在线 | 啪啪激情婷婷久久婷婷色五月 | 亚洲午夜精品A片久久WWW软件 | 日韩在线看片中文字幕不卡 | 国产亚洲精品久久久久久久软件 | 暖暖 免费 高清 日本视频大全 | 日韩精品久久久久影院 | 寻找最美乡村教师颁奖晚会 | 精品一区二区三区免费观看 | 深夜释放自己污在线看 | 亚洲高清在线精品一区 | 国产情侣真实露脸在线 | 色99久久久久高潮综合影院 | 日日射日日操 | 国产亚洲精品精品精品 | 美女扒开屁股让男人桶 | 日韩做A爰片久久毛片A片毛茸茸 | 国产午夜高潮熟女精品AV | 亚洲AV午夜福利精品香蕉麻豆 | 精品美女国产互换人妻 | 亚洲精品久久99蜜芽尤物TV | 蜜臀AV999无码精品国产 | 最新日本免费一区 | 久久精品观看影院2828 | 欧美成人免费观看久久 | 最近的中文字幕免费完整 | 伊人国产在线视频 | 欧美成人中文字幕在线看 | 国产中文字幕乱码免费 |