摘要:針對Web數據打印缺乏靈活性的問題,使用中間件動態生成的XML,結合XSL如Document對象,提出了幾種用戶可自定義打印格式的通用解決方案。該方案應用于“國有資產智能管理系統”項目取得了良好的效果。
關鍵詞:中間件;XML;XSL;Document;數據打印;Web
0 引言
隨著數據庫技術與網絡的發展以及互聯網的普及,基于B/S(Browser/Server)模式的軟件應用越來越廣泛。大多數管理信息系統在應用中都有數據打印需求,因此對Web數據打印的研究非常重要。
目前常用的Web數據打印的方式有:
簡單應用:將需要打印的數據以表格標志(<table>、<tr>、<th>、<td>)組織成HTML文件,以瀏覽器(如IE)顯示并打印。其優點為處理與實現簡單。缺點是缺乏靈活性,不能由用戶自定義格式,形式太單調;數據多頁顯示時,分頁打印定位不準確。
模板打印:利用開發工具(如Java)開發一個ActiveX控件,安裝在需要打印的客戶端,用戶自定義打印格式并以模板文件的形式存儲,只需傳遞相應的數據給對應的模板文件就可以按照用戶要求打印。這種方式的優點為不需要開發人員修改程序,用戶可以利用開發人員提供模板修改工具直接修改模板文件保存所需的格式。缺點是開發此模板處理工具比較復雜,或要向專業公司購買類似的工具。
本文克服了Web數據打印的不靈活性以及模板處理工具復雜性等缺陷,利用中間件技術(EJB、COM)動態生成XML,結合不同的XSL文件,得到形式豐富多樣的格式,以滿足用戶自定義的需求;又可以通過參數設置選擇不同的數據項(數據字段)得到不同的打印數據;還可以設置顯示頁面數據的記錄數,結合Document對象動態生成HTML文件以確保分頁定位準確的數據打印。實際應用證明,方案靈活、實現簡單,是可行的通用方法。
1 中間件技術生成XML數據

XML(extensible Markup Language)是網絡第二代語言,可以定義無窮無盡的標志來描述文件中的任何數據元素,突破了HTML固定標記集合的約束,使文件的內容更豐富并組成一個完整的信息體系。XML具有良好的數據結構,已成為廣泛接受的數據傳輸標準。
Web應用服務器調用中間件(EJB、COM)接口,通過設置的參數獲得封裝的XML數據片段。下面我們在VJ++環境中考慮XML數據的生成。
在VJ++中使用XML接口主要是通過微軟提供的Msxm12.dll實現。該動態鏈接庫提供了對符合XML標準的所有對象進行操作的方法。其中,主要的接口有:DOMDocument26,IXMLDOMNode,IXMLDOMNodeList,IXMLDOMNamedMap,IXMLDOMAtrribute等。
在國資項目中獲取企業信息的XML片段則通過COM對象Enpr的接口實現:
public String getEnprByCondition(int pageNum,intpageRecord,String QueryCondition,String SortCondition)
其中:函數getEnprByCondition以字符串形式返回企業XML信息;
參數pageRecord是分頁傳遞數據時每頁顯示的記錄數;
參數pageNum是分頁傳遞數據時第pageNum頁的數據;
參數QueryCondition是獲取數據設置的過濾條件;
參數SortCondition是獲取數據設置的排序條件。
2 解決方案
下面給出3種解決方案:
2.1 XML與XSL相結合生成動態的HTML
使用此方案,用戶在數據打印前可通過預覽確認數據是否符合要求,并通過數據字段的選擇確認打印內容(如圖1,圖2);若頁面數據太多等,可重設“頁記錄數”等參數加以調整(如圖3,圖4);對同一XML片段,若數據排列格式需變化可通過選擇預定義的XSL文件作為參數調整生成動態的HTML(如圖5),同時也可直接修改XSL文件,從而得到形式多樣的打印格式。
操作步驟如下:
(1)用戶通過瀏覽器(browser)設置參數:XSL文件名,頁記錄數,第幾頁,查詢條件等,然后向Web服務器請求。
(2)Web服務器響應,獲取參數并調用中間件(COM)對象接口生成XML片段,同時選擇XSL文件,處理數據節點,以HTML格式反饋給客戶端。
(3)用戶預覽確認是否符合需求,若格式不合,繼續執行步驟(1),否則打印數據。
2.2×ML數據片段導入EXCEL
在Web頁面中嵌入MSOWC(Microsoft Office WebComponents)的Spreadsheet Component對象,將XML數據賦給此對象,利用Spreadsheet Component對象的“導出到Excel”功能即可生成Excel文件(如圖6)。

圖6打印數據導入EXCEL
部分代碼如下:
2.3×ML數據與Document對象動態輸出HTML文件
Web應用服務器調用中間件生成XML數據,頁面(ASP)通過Microsoft.XMLDOM類對象就可以訪問XML數據中的任何節點內容,并由頁面內置對象Document的Write方法動態輸出HTML文件(如圖7)。分頁設置通過CSS控制。打印數據字段、內容以及頁記錄數由用戶通過參數設置。
部分代碼如下:
var xmIDoc=new ActiveXObject(\"Microsoft.XMLDOM\"):
//創建XMLDOM對象
xmIDoc.10ad(XMLData);//XMLDOM對象裝載XML數據
document.writef(\"<style media=print>.PageNext
{page-break-after:always;}</style>”)://分頁標志
var xmlNodes=xmIDoc.selectNodes(\"//Record\");//生成記錄節點
xmlNodes item(i).selectSingleNode(\"Field[@FName=
'OrganType'n\").text;//獲取第i條記錄的字段“OrganType”的值
document.write(\"<br><center>共\"+pageCount+\"頁第\"
+curPage+\"頁</center><div class='PageNext'></div>”)
//分頁設置,頁尾說明

圖7 分頁打印數據
3 方案比較
(1)XML與XSL相結合生成動態的HTML:該方案一般適應于單頁數據打印,可以提供豐富多樣的格式。
(2)XML數據片段導入EXCEL:該方案適應于需要調整打印數據的情況,通過導出Excel到文件,用戶可對數據進行處理,是較靈活的一種方式。
(3)XML數據與Document對象動態輸出HTML文件:該方案適應于數據比較多的連續打印情況。
4 結束語
本文介紹了在VJ++環境利用中間件(COM)封裝XML數據的方法。通過XML,結合XSL,Document等對象提出了三種打印方案,并給出相應的實現。比較了三種方案的適用范圍。“國有資產智能管理系統”的應用效果表明,方案不失為通用的數據打印方法。
注:本文中所涉及到的圖表、注解、公式等內容請以PDF格式閱讀原文。