巧用FileSystem組件實現WEB應用中的本地特定打印
當前位置:點晴教程→知識管理交流
→『 技術文檔交流 』
[p]1、引言 [br]隨著internet的飛速發展,許多企業都紛紛開發基于web的業務應用系統。一般情況下,基于web的業務應用都采用三層或三層以上的結構,前臺即客戶端是普通的web瀏覽器,中間業務邏輯應用層存放于web服務器上,由web服務器上的服務構件訪問后臺數據庫。為了業務系統與internet的互聯,web服務器和數據庫系統均托管在idc(互聯網數據中心),因而需要從托管在 idc的服務器上提取業務數據在本地打印輸出。在客戶端瀏覽器只能打印簡單的html頁面的情況下,要求更為強大靈活的打印輸出功能;通過采用相關的技術對瀏覽器的功能進行擴展,能夠完成更復雜的數據打印的任務,如收條、回執等。筆者曾經為一網絡教育公司開發教育管理軟件時采用filesystem組件實現在本地打印三聯收款憑證和準考證等的功能。 [br]2、filesystem組件使用簡介 [br]filesystem組件其實是一個activex控件,其存在于windows平臺中(不管是win98、win2000,還是nt環境都包含該組件。),clsid:0d43fe01-11cf-8940-00a0c9054228。熟悉asp編程人可能都使用過filesystem組件,一般情況下該組件用在服務器端,用來對文本文件、文件夾及驅動器進行訪問和控制。可以通過兩種方法創建filesystem組件的對象實例: [br]1、使用asp的內置對象server的方法server.createobject來創建服務器端對象的實例。 [br]2、使用vbscript腳本函數createobject來創建客戶端對象的實例(也可以在服務器端用該方法,但有時會出錯,一般不使用;)。 [br]filesystem組件對文本文件進行操作有如下方法: [br]createtextfile(filename,[overwrite if exists],[unicode/ascii]) //創建文本文件 [br]opentextfile(filename,[input/output mode],[create if not exists],[format]) //打開文本文件 [br]copyfile(filename1,filename2,[overwrite]) //拷貝文本文件 [br]movefile (filename1,filename2) //移動文本文件 [br]deletefile (filename) //刪除文本文件 [br]getfile (filename) //獲得文本文件 [br]fileexists (filename) //判斷文本文件是否存在 [br]filesystem組件對文件夾和驅動器也有和文本文件相類似的方法,在此不一一贅述。 [br]其實,filesystem組件也可使用于客戶端,采用創建filesystem組件對象實例的第二種方法即可以使用該組件對客戶端系統的文本文件、文件夾及驅動器進行訪問和控制。因為微軟平臺帶有filesystem組件,所以對于微軟平臺的客戶端則不需要從遠程服務器下載,其在安裝操作系統時會自己安裝并注冊;而對于其他平臺的客戶端則須安裝插件并下載filesystem組件。 [br]3、本地端特定打印的實現機制 [br]利用filesystem組件實現本地端特定打印的過程如圖所示: [br][br]1、客戶端向web服務器發送數據請求; [br]2、web服務器根據業務處理邏輯與后臺數據庫進行交互,取得所需數據形成html頁面,并附帶有filesystem組件對象的vbscript腳本,向客戶端瀏覽器發回html頁面; [br]3、在客戶端運行腳本,腳本取得html頁面構件的數據,建立與打印機的連接,向打印機輸出打印數據。 [br]前兩步與一般的web應用沒有什么區別,需要說明的是第三步:首先使用vbscript腳本函數createobject來創建filesystem組件對象的實例;然后調用該實例創建文本文件的createtextfile方法,把打印端口lpt1或lpt2作為文件名參數,并將可覆蓋文件參數設為true,建立與打印機的連接;調用獲得的打印機文本文件流實例的寫文本方法writeline向打印機輸出打印的內容。 [br]4、程序示例 [br]客戶端腳本: [br] [br]服務器端腳本: [br]<%……… [br]set conn=server.createobject ("adodb.connection") [br]conn.open "dsn=name;uid=xxxx;pwd=xxxx;" [br]set rs=server.createobject("adodb.recordset") [br]rs.open(“select ……”),conn,1,1 [br]……….%> //與數據庫進行交互 [br]html頁面編碼: [br] [br]……… [br]
|
關鍵字查詢
相關文章
正在查詢... |