摘要:針對(duì)Web數(shù)據(jù)打印缺乏靈活性的問(wèn)題,使用中間件動(dòng)態(tài)生成的XML,結(jié)合XSL如Document對(duì)象,提出了幾種用戶可自定義打印格式的通用解決方案。該方案應(yīng)用于“國(guó)有資產(chǎn)智能管理系統(tǒng)”項(xiàng)目取得了良好的效果。
關(guān)鍵詞:中間件;XML;XSL;Document;數(shù)據(jù)打??;Web
0 引言
隨著數(shù)據(jù)庫(kù)技術(shù)與網(wǎng)絡(luò)的發(fā)展以及互聯(lián)網(wǎng)的普及,基于B/S(Browser/Server)模式的軟件應(yīng)用越來(lái)越廣泛。大多數(shù)管理信息系統(tǒng)在應(yīng)用中都有數(shù)據(jù)打印需求,因此對(duì)Web數(shù)據(jù)打印的研究非常重要。
目前常用的Web數(shù)據(jù)打印的方式有:
簡(jiǎn)單應(yīng)用:將需要打印的數(shù)據(jù)以表格標(biāo)志(<table>、<tr>、<th>、<td>)組織成HTML文件,以瀏覽器(如IE)顯示并打印。其優(yōu)點(diǎn)為處理與實(shí)現(xiàn)簡(jiǎn)單。缺點(diǎn)是缺乏靈活性,不能由用戶自定義格式,形式太單調(diào);數(shù)據(jù)多頁(yè)顯示時(shí),分頁(yè)打印定位不準(zhǔn)確。
模板打?。豪瞄_發(fā)工具(如Java)開發(fā)一個(gè)ActiveX控件,安裝在需要打印的客戶端,用戶自定義打印格式并以模板文件的形式存儲(chǔ),只需傳遞相應(yīng)的數(shù)據(jù)給對(duì)應(yīng)的模板文件就可以按照用戶要求打印。這種方式的優(yōu)點(diǎn)為不需要開發(fā)人員修改程序,用戶可以利用開發(fā)人員提供模板修改工具直接修改模板文件保存所需的格式。缺點(diǎn)是開發(fā)此模板處理工具比較復(fù)雜,或要向?qū)I(yè)公司購(gòu)買類似的工具。
本文克服了Web數(shù)據(jù)打印的不靈活性以及模板處理工具復(fù)雜性等缺陷,利用中間件技術(shù)(EJB、COM)動(dòng)態(tài)生成XML,結(jié)合不同的XSL文件,得到形式豐富多樣的格式,以滿足用戶自定義的需求;又可以通過(guò)參數(shù)設(shè)置選擇不同的數(shù)據(jù)項(xiàng)(數(shù)據(jù)字段)得到不同的打印數(shù)據(jù);還可以設(shè)置顯示頁(yè)面數(shù)據(jù)的記錄數(shù),結(jié)合Document對(duì)象動(dòng)態(tài)生成HTML文件以確保分頁(yè)定位準(zhǔn)確的數(shù)據(jù)打印。實(shí)際應(yīng)用證明,方案靈活、實(shí)現(xiàn)簡(jiǎn)單,是可行的通用方法。
1 中間件技術(shù)生成XML數(shù)據(jù)
XML(extensible Markup Language)是網(wǎng)絡(luò)第二代語(yǔ)言,可以定義無(wú)窮無(wú)盡的標(biāo)志來(lái)描述文件中的任何數(shù)據(jù)元素,突破了HTML固定標(biāo)記集合的約束,使文件的內(nèi)容更豐富并組成一個(gè)完整的信息體系。XML具有良好的數(shù)據(jù)結(jié)構(gòu),已成為廣泛接受的數(shù)據(jù)傳輸標(biāo)準(zhǔn)。
Web應(yīng)用服務(wù)器調(diào)用中間件(EJB、COM)接口,通過(guò)設(shè)置的參數(shù)獲得封裝的XML數(shù)據(jù)片段。下面我們?cè)赩J++環(huán)境中考慮XML數(shù)據(jù)的生成。
在VJ++中使用XML接口主要是通過(guò)微軟提供的Msxm12.dll實(shí)現(xiàn)。該動(dòng)態(tài)鏈接庫(kù)提供了對(duì)符合XML標(biāo)準(zhǔn)的所有對(duì)象進(jìn)行操作的方法。其中,主要的接口有:DOMDocument26,IXMLDOMNode,IXMLDOMNodeList,IXMLDOMNamedMap,IXMLDOMAtrribute等。
在國(guó)資項(xiàng)目中獲取企業(yè)信息的XML片段則通過(guò)COM對(duì)象Enpr的接口實(shí)現(xiàn):
public String getEnprByCondition(int pageNum,intpageRecord,String QueryCondition,String SortCondition)
其中:函數(shù)getEnprByCondition以字符串形式返回企業(yè)XML信息;
參數(shù)pageRecord是分頁(yè)傳遞數(shù)據(jù)時(shí)每頁(yè)顯示的記錄數(shù);
參數(shù)pageNum是分頁(yè)傳遞數(shù)據(jù)時(shí)第pageNum頁(yè)的數(shù)據(jù);
參數(shù)QueryCondition是獲取數(shù)據(jù)設(shè)置的過(guò)濾條件;
參數(shù)SortCondition是獲取數(shù)據(jù)設(shè)置的排序條件。
2 解決方案
下面給出3種解決方案:
2.1 XML與XSL相結(jié)合生成動(dòng)態(tài)的HTML
使用此方案,用戶在數(shù)據(jù)打印前可通過(guò)預(yù)覽確認(rèn)數(shù)據(jù)是否符合要求,并通過(guò)數(shù)據(jù)字段的選擇確認(rèn)打印內(nèi)容(如圖1,圖2);若頁(yè)面數(shù)據(jù)太多等,可重設(shè)“頁(yè)記錄數(shù)”等參數(shù)加以調(diào)整(如圖3,圖4);對(duì)同一XML片段,若數(shù)據(jù)排列格式需變化可通過(guò)選擇預(yù)定義的XSL文件作為參數(shù)調(diào)整生成動(dòng)態(tài)的HTML(如圖5),同時(shí)也可直接修改XSL文件,從而得到形式多樣的打印格式。
操作步驟如下:
(1)用戶通過(guò)瀏覽器(browser)設(shè)置參數(shù):XSL文件名,頁(yè)記錄數(shù),第幾頁(yè),查詢條件等,然后向Web服務(wù)器請(qǐng)求。
(2)Web服務(wù)器響應(yīng),獲取參數(shù)并調(diào)用中間件(COM)對(duì)象接口生成XML片段,同時(shí)選擇XSL文件,處理數(shù)據(jù)節(jié)點(diǎn),以HTML格式反饋給客戶端。
(3)用戶預(yù)覽確認(rèn)是否符合需求,若格式不合,繼續(xù)執(zhí)行步驟(1),否則打印數(shù)據(jù)。
2.2×ML數(shù)據(jù)片段導(dǎo)入EXCEL
在Web頁(yè)面中嵌入MSOWC(Microsoft Office WebComponents)的Spreadsheet Component對(duì)象,將XML數(shù)據(jù)賦給此對(duì)象,利用Spreadsheet Component對(duì)象的“導(dǎo)出到Excel”功能即可生成Excel文件(如圖6)。
圖6打印數(shù)據(jù)導(dǎo)入EXCEL
部分代碼如下:
2.3×ML數(shù)據(jù)與Document對(duì)象動(dòng)態(tài)輸出HTML文件
Web應(yīng)用服務(wù)器調(diào)用中間件生成XML數(shù)據(jù),頁(yè)面(ASP)通過(guò)Microsoft.XMLDOM類對(duì)象就可以訪問(wèn)XML數(shù)據(jù)中的任何節(jié)點(diǎn)內(nèi)容,并由頁(yè)面內(nèi)置對(duì)象Document的Write方法動(dòng)態(tài)輸出HTML文件(如圖7)。分頁(yè)設(shè)置通過(guò)CSS控制。打印數(shù)據(jù)字段、內(nèi)容以及頁(yè)記錄數(shù)由用戶通過(guò)參數(shù)設(shè)置。
部分代碼如下:
var xmIDoc=new ActiveXObject(\"Microsoft.XMLDOM\"):
//創(chuàng)建XMLDOM對(duì)象
xmIDoc.10ad(XMLData);//XMLDOM對(duì)象裝載XML數(shù)據(jù)
document.writef(\"<style media=print>.PageNext
{page-break-after:always;}</style>”)://分頁(yè)標(biāo)志
var xmlNodes=xmIDoc.selectNodes(\"//Record\");//生成記錄節(jié)點(diǎn)
xmlNodes item(i).selectSingleNode(\"Field[@FName=
'OrganType'n\").text;//獲取第i條記錄的字段“OrganType”的值
document.write(\"<br><center>共\"+pageCount+\"頁(yè)第\"
+curPage+\"頁(yè)</center><div class='PageNext'></div>”)
//分頁(yè)設(shè)置,頁(yè)尾說(shuō)明
圖7 分頁(yè)打印數(shù)據(jù)
3 方案比較
(1)XML與XSL相結(jié)合生成動(dòng)態(tài)的HTML:該方案一般適應(yīng)于單頁(yè)數(shù)據(jù)打印,可以提供豐富多樣的格式。
(2)XML數(shù)據(jù)片段導(dǎo)入EXCEL:該方案適應(yīng)于需要調(diào)整打印數(shù)據(jù)的情況,通過(guò)導(dǎo)出Excel到文件,用戶可對(duì)數(shù)據(jù)進(jìn)行處理,是較靈活的一種方式。
(3)XML數(shù)據(jù)與Document對(duì)象動(dòng)態(tài)輸出HTML文件:該方案適應(yīng)于數(shù)據(jù)比較多的連續(xù)打印情況。
4 結(jié)束語(yǔ)
本文介紹了在VJ++環(huán)境利用中間件(COM)封裝XML數(shù)據(jù)的方法。通過(guò)XML,結(jié)合XSL,Document等對(duì)象提出了三種打印方案,并給出相應(yīng)的實(shí)現(xiàn)。比較了三種方案的適用范圍。“國(guó)有資產(chǎn)智能管理系統(tǒng)”的應(yīng)用效果表明,方案不失為通用的數(shù)據(jù)打印方法。
注:本文中所涉及到的圖表、注解、公式等內(nèi)容請(qǐng)以PDF格式閱讀原文。