巧用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]
|
关键字查询
相关文章
正在查询... |