封装为dll会带来很多的好处,主要包括只是产权的保护,以及效率和安全性能的提升。这个例子中被封装的dll文件可以隐藏access数据库的实际路径。VB生成的DLL封装ASP代码来连接数据库(Access)。本文用一个最简单的连接access数据库的例子来说明如何将asp代码封装为dll文件。我们用vb,最常见的方式来封装asp代码。我们需要封装的对象如下: 'Proconn.aspdim ProConnset ProConn=Server.CreateObject("ADODB.CONNECTION")ProConn.Open "driver={Microsoft Access Driver (*.mdb)};uid=;pwd=123;DBQ=" & Server.MapPath("DB.asp")我们将下面的部分封装"driver={Microsoft Access Driver (*.mdb)};uid=;pwd=123;DBQ=" & Server.MapPath("DB.asp")分析一下这段要封装的内容,它的前半部分就是一个字符串:"driver={Microsoft Access Driver (*.mdb)};uid=;pwd=123;DBQ="用&连接上后半部分的另一个字符串。后半部分的另一个字符串是Server.MapPath对象函数的返回值。下面开始这个封装的操作过程。首先新建一个VB下的ActiveX DLL工程,工程的名称Project1更改成ConDBDLL方法class1的名称更改成cs工程名和方法名会在调用这个DLL的时候使用到,大家可以按照自己命名规则定义,但请注意好好使用。这个DLL的代码部分书写如下:Dim rp As ResponseDim rq As RequestDim ap As ApplicationDim sr As ServerDim sn As SessionPublic Sub OnStartPage(MyScriptingContext As ScriptingContext)Set rp = MyScriptingContext.ResponseSet rq = MyScriptingContext.RequestSet sr = MyScriptingContext.ServerSet ap = MyScriptingContext.ApplicationSet sn = MyScriptingContext.SessionEnd SubPublic Sub OnEndPage()Set rp = NothingSet rq = NothingSet sr = NothingSet ap = NothingSet sn = NothingEnd Sub'以上语句是必须的,将原本的对象作了简化处理,并在两个基本函数中作了处理Public Function ConnectDB() As VariantConnectDB = "driver={Microsoft Access Driver (*.mdb)};uid=;pwd=123;DBQ="End Function'上面这个函数是处理前半部分字符串的,直接返回这个字符串的内容'另外定义下面这个函数来处理后半部分内容Public Function DBPath() As VariantDBPath = sr.MapPath("DB.asp")End Function'注意上面使用的是sr,不要使用成Server了到了关键的一步,给这个工程添加"Microsoft Active Server Pages ObjectContext Object Library" 的 Reference添加方法,选择菜单中的"Project"->"Reference",在打开的对话框里选择。对了,还要选择上"microsoft activeX data objects 2.6 library"进行完以上操作,我们就可以编译生成DLL了,(别忘了前面的改工程名和方法名)准备好数据库文件DB.asp (由DB.mdb更改后缀而成,密码123)下面就是调用封装的连接数据库的asp文件代码: 由于是自己创建的DLL,把它拷贝到相应的目录后,必须注册才能使用。注册的方法,在“运行”中执行:Regsvr32.exe dllname.dll取消这个DLL的注册的方法是:Regsvr32.exe /u dllname.dll注册完毕,我们的工作基本上就做完了,现在我们可以使用这样的封装方法连接具有针对性的数据库了。不过有一点需要特别注意的是:由于Dim ConDBset ConDB=Server.CreateObject("ConDBDLL.Conn")'ConDB就是创建的DLL对象这是在ASP中创建的对象,包括ProConn,那么我们在任何使用到(引用)ProConn.asp的其他ASP文件中记得释放这两个对象!ProConn.closeset ProConn=nothingset ConDB=Nothing否则系统会由于对象没有释放,而变得越来越不堪重负。关于这个封装ASP代码连接Access数据库的方法,我想完全适用其他数据库的连接方法。再例如,下面的封装的例子:首先要申明变量:Private WenScriptingContext As ScriptingContextPrivate WenApplication As ApplicationPrivate WenRequest As RequestPrivate WenResponse As ResponsePrivate WenServer As ServerPrivate WenSession As Session为了在WenConnection类中使用ASP的内建对象,必须在此类中写一个OnStartPage子函数。那是因为无论什么时候用户访问一个带有本组件的ASP文件,IIS就会把ScriptingContext传送给我们的对象请我们使用。这个ScriptingContext包括了全部的ASP方法和属性,这使得我们有能力访问所有ASP的对象。Public Sub OnStartPage (PassedScriptingContext As ScriptingContext)Set WenScriptingContext = PassedScriptingContextSet WenApplication = WenScriptingContext.ApplicationSet WenRequest = WenScriptingContext.RequestSet WenResponse = WenScriptingContext.ResponseSet WenServer = WenScriptingContext.ServerSet WenSession = WenScriptingContext.SessionEnd Sub我们既然用OnStartPage函数来创建对象,那么我们这里就用OnEndPage子函数来释放对象:Public Sub OnEndPage()Set WenScriptingContext = NothingSet WenApplication = NothingSet WenRequest = NothingSet WenResponse = NothingSet WenServer = NothingSet WenSession = NothingEnd Sub接下来定义两个函数RsResult()和DataSource():Public Function Rs(strsql As String) As RecordsetDim oConn As ConnectionDim oRs As RecordsetDim strconnstring As Stringstrconnstring = "driver={sql server};server=ServerName;uid=sa;pwd=;" & _"database=DataBaseName"oConn.Open strconnstringoRs.ActiveConnection = oConnstrsql="Select * From tableName"oRs.Open strsql,oConn,1,3Set Rs = oRsEnd Function Public Function DataSourceConnection() As VariantDataSourceConnection = "driver={sql server};server=ServerName;uid=sa;pwd=;database=DataBaseName"End Function三、 存工程名为WenADODB.vbp和保存类名为WenConnection.cls,然后点击“文件”—>“生成WenADODB.DLL”编译成动态连接库文件。VB在编译好动态连接库文件的同时也将该组件注册到注册表里了,要是想在另外一台机器上注册该组件的话,请用以下指令注册或反注册:Regsvr32 x:/路径/WenADODB.dll x:/路径/为WenADODB.dll文件存放的盘符和路径Regsvr32 /u x:/路径/WenADODB.dll 参数U为反注册四、 在ASP文件中调用WenADODB.dll组件的例子。<%Set Conn=Server.CreateObject("WenADODB.WenConnection") ‘调用组件创建对象实例objConn=Conn.DataSourceConnection()application("strconn")=objConn set Rs=Server.CreateObject("ADODB.Recordset")sql="select * from TableName order by ID DESC"Rs.open sql,application("strconn"),3%><Table align="center" border="1"><% if Rs.Bof and Rs.Eof thenResponse.Write "暂时还没有任何数据。"elseDo while not Rs.Eof %><tr width=100%><td width=50%><%=Rs("Field1")%></td><td width=50%><%=Rs("Field2")%></td></tr><%Rs.MoveNextLoopend ifRs.Close;Set Rs=Nothing%></Table>五、 小结我们这里只是编写了一个连接数据库的简单的动态连接库文件,利用VB的强大组件编写功能还可以写出功能更加强大跟齐全的组件,来完成更加实用的任务 关键字 如何把ASP编写成DLL 这篇文章主要是把ASP代码变成组件,开发者不仅是加快了ASP的速度,而且也能保护自己的代码.下面,我们会来编写一个非常简单的组件,重点是知道怎样开发DLL组件,而不是其复杂的代码!这些都要靠你们自己以后的努力了.服务器端组件首先,服务器端的组件要有别于客户端的组件.客户端的组件是通过网络传输,依靠HTML来起作用.而且只能在IE上有用.但是服务器端的组件是运行在服务器端,它在服务器上执行各种操作.因此,所有的浏览器都能享用,它依靠的是服务器而不是浏览器.当IIS被请求执行一个ASP程序,它首先会在ASP文件中找到〈%%>标签之间的代码,并且执行它(也可以是〈scriptrunat=server>〈/script>之间的代码).如果这个ASP程序在先前被调用过,那么它就会用内存中的编译过的程序来向用户返回HTML代码,如果没有,那么它就重新编译.这里ASP就比CGI多一点速度优势,因为CGI是每一个请求都使用一个线程.这样就大大消耗了服务器的资源.想不想你写的程序自己就能在IIS运行!?!现在你就行了!使用VB5(当然现在是VB6了),你就能建立DynamicLinkedLibraries(DLL文件),它能在IIS上直接运行(如果有asp文件来请求的话).系统和软件的要求你需要一个32位的操作系统来运行ASP.当然你也得安装IIS或PWS.我们下面的程序是在windows95+PWS+VB5的环境下开发的.我们开始吧启动你的VB,选择ActiveX图标.这个图标可以在新建工程找到!VB会提供一个默认的工程名(project1)和类名(class1).我们会将这两个名字都改掉.在改名之前,请首先确认我们拥有MicrosoftActiveServerPagesObjectLibrary,它在我们的程序非常有用.从菜单中选择"工程",然后在其中选择"引用",就会出现"引用"窗口从中选择MicrosoftActiveServerPagesObjectLibrary.给工程和类命名现在我们来根据自己的爱好来为project1和class1来命名吧!给它们命名也是很重要的,我们以后会用这个工程名和类名来创建这个组件的实例!后面详细介绍.如何改名,我就不想多说了!我们的工程名改为Exmaple,类名为Helloword怎样使用工程和类现在我们有了我们自己的工程(Example1)和类名(HelloWorld).以后我们就会在ASP代码中使用它们的名字来引用这个组件.在ASP中我们就这样引用,如下:SetObjReference=Server.CreateObject("ProjectName.ClassName")对于我们工程的引用就是:SetObjReference=Server.CreateObject("Example1.HelloWorld")现在我们就能用ObjReference来调用我们在组件中所创建的函数,子程序.下面我们会来写一个SayHello的子程序,我们执行它的代码如下:〈%SetObjReference=Server.CreateObject("Example1.HelloWorld")ObjReference.SayHello%>为了在Helloword类中使用ASP的方法,你必须在此类中写一个OnStartPage子函数.如下:PublicSubOnStartPage(PassedScriptingContextAsScriptingContext)SetMyScriptingContext=PassedScriptingContextEndSub现在,无论什么时候用户访问一个带有本组件的ASP文件,IIS就会把ScriptingContext传送给我们的对象请我们使用.这个ScriptingContext包括了全部的ASP方法和属性.实现上,这使得我们有能力访问所有ASP的对象.看下面的代码:PublicSubOnStartPage(PassedScriptingContextAsScriptingContext)SetMyScriptingContext=PassedScriptingContextSetMyApplication=MyScriptingContext.ApplicationSetMyRequest=MyScriptingContext.RequestSetMyResponse=MyScriptingContext.ResponseSetMyServer=MyScriptingContext.ServerSetMySession=MyScriptingContext.SessionEndSub以后我们就能用在VB中用MyApplication来代替ASP中的Application,同理可以代替Request,Server.....,不过我们来是要在OnStartPage之前来申明这些变量:PrivateMyScriptingContextAsScriptingContextPrivateMyApplicationAsApplicationPrivateMyRequestAsRequestPrivateMyResponseAsResponsePrivateMyServerAsServerPrivateMySessionAsSession使用ASP的对象我们的变量现在就能像标准的ASP对象来使用了!比如,我们经常在ASP中用Request.form()来收集提交表单的数据.现在我们在我们的VB中实现这个功能,代码如下:用ASP中实现:〈%MyTempVariable=Request.Form("userName")Response.Write("youentered"&MyTempVariable&"asyourusername")%>在VB中实现:MyTempVariable=MyRequest.Form("userName")MyResponse.Write("youentered"&MyTempVariable&"asyourusername")通过使用MyResponse来代替Response,我们能够使用所有Response的方法,当然,MyResponse这个名字可以随便来取,你甚至可以就取Response.另一件我们得注意的是,我们得在我们的建立的类中,写上OnEndPage子函数,这个OnStartPage是相反的!OnStartPage是创建对象,OnEndPage是消毁对象.PublicSubOnEndPage()SetMyScriptingContext=NothingSetMyApplication=NothingSetMyRequest=NothingSetMyResponse=NothingSetMyServer=NothingSetMySession=NothingEndSubSayHello方法我们来建立一个子函数,用于显示"HolleWorld".这个SayHello方法只是HelloWorld这个类中一个子函数,我们以后会在ASP中用以下的显示这个方法〈%SetObjReference=Server.CreateObject("Example1.HelloWorld")ObjReference.SayHello%>SayHello的程序,很简单的!PublicSubSayHello()MyResponse.Write("HelloWorld")EndSub现在一个小型的组件编写完成,剩下的工作就是编译这个组件,在"工程"菜单中保存它,取什么名字都可以,我们用Exmaple1.vbp吧!然后就用在菜单中选择"makeexmaple1.dll",将其编译成DLL文件.一个组件就真正完成了!注意,编译了此组件那么你就得先把你的PWS关掉,然后再编译此组件.否则VB就会告诉你些组件在使用中.在ASP中使用我们的自己的组件.当你更正了在编译中的错误,成功地编译了example1这个工程,现在你就得拿出你最喜欢的HTML编辑器来写下下面的语句,保存为ASP文件.〈HTML>〈HEAD>〈TITLE>Example1〈/TITLE>〈/HEAD>〈BODY>〈%SetObjReference=Server.CreateObject("Example1.HelloWorld")ObjReference.SayHello%>〈/BODY>〈/HTML>运行后即可看到结果:HelloWorld注册组件如果你想和你的朋友,邻居分享你的组件,那么你就得在你的系统上注册你的组件.我们一般使用Regsvr32.exe来注册组件.注册后你的组件会出现在Win95/Win98的windows/system目录中.下面是一个注册的例子:Regsvr32.exeC:/wwwroot/Example1/Example1.dll在你的系统中,VB会自动给你注册,所以你很少用到Regsvr32.exe这里只是写了一个非常小的组件,你可以写好自己的更大的组件,而且还可以用VB中的很多控件. 附录:建立注册DLL和反注册DLL文件的快捷方式有的程序员经常要注册或者反注册自己写的dll文件,加一个快捷方式会减少自己的工作量:Windows Registry Editor Version 5.00[HKEY_CLASSES_ROOT/dllfile/shell][HKEY_CLASSES_ROOT/dllfile/shell/register][HKEY_CLASSES_ROOT/dllfile/shell/register/command]@="regsvr32 %1"[HKEY_CLASSES_ROOT/dllfile/shell/Unregister]"Command"="regsvr32 %1 /u"[HKEY_CLASSES_ROOT/dllfile/shell/Unregister/command]@="regsvr32 %1 /u"当我们需要注册或者反注册dll时,只要在该dll文件上按下鼠标右键即可!附录注册和注销dll文件的方法:一个快速注册 DLL 及 OCX 的方法 有时候我们在 VB 中要引用某一个 DLL 或 OCX 时,会出现文件未注册的讯息,这时,我们可以使用人工注册的方法,也就是直接在命令列中使用 regsvr32.exe 来做,做法如下: 文件注册:C:/Windows/System/Regsvr32.exe C:/Windows/System/Test.ocx取消注册:C:/Windows/System/Regsvr32.exe /u C:/Windows/System/Test.ocx这些动作我们也可以直接写到程序中,使用 Shell 来执行,但是我现在要说的,都不是上面提到的方法!1、在资源管理器中找到 C:/Windows/System/Regsvr32.exe 并【复制】 ( 按鼠标右键选复制 )2、将目录移到 C:/Windows/SendTo 后,执行【贴上快捷方式】 ( 按鼠标右键选贴上快捷方式 )3、将快捷方式名称改成【REGISTER】4、OK现在,如果您想替某一个文件做注册动作,例如:C:/Windows/System/Test.ocx,您只要打开资源管理器,找到 C:/Windows/System/Test.ocx,按鼠标右键选【传送到】【REGISTER】即可完成注册动作了!注:有一个地方要注意的是,Regsvr32.exe 只能注册 32 位的文件!如果要用它来注册 16 位的文件,会有错误讯息产生。 附录 某些dll文件的功能:一、轻松修复IE浏览器 很多经常上网的朋友都有过 这样的遭遇:IE不能打开新的窗口,用鼠标点击超链接也没有任何反应。这时重装IE一般能解决问题。其实不必这么麻烦,使用Regsvr32命令就可以轻松搞定。 在“开始→运行”中键入“regsvr32 actxprxy.dll”命令,点击“确定”按钮,这时会弹出一个信息对话框“DllRegisterServer in actxprxy.dll succeeded”,点击“确定”;然后再在“开始→运行”中键入“regsvr32 shdocvw.dll”命令,单击“确定”即可。重新启动后IE已经被轻松修复了。二、解决Windows无法在线升级的问题 Windows的漏洞很多,每隔一段时间就需要使用“Windows Update”升级程序进行在线升级,不过“Windows Update”经常出现无法使用的情况,这时,我们可以使用Regsvr32来解决这个问题。 在“开始→运行”中键入“regsvr32 wupdinfo.dll”,点击“确定”按钮,这样在系统中就重新注册了“Windows Update”组件,重新启动后问题已经解决。三、防范网络脚本病毒有新招 网络脚本病毒嵌在网页中,上网时在不知不觉中机器就会感染上这种病毒。笔者认为单纯使用杀毒软件并不能有效地防范这些脚本病毒,必须从病毒传播的机理入手。网络脚本病毒的复制、传播都离不开FSO对象(File System Object,文件系统对象),因此禁用FSO对象就能有效地控制脚本病毒的传播。操作方法很简单: 在“开始→运行”中键入“regsvr32 /u scrrun.dll”就可以禁用FSO对象;如果需要使用FSO对象,键入“regsvr32 scrrun.dll”命令即可。四、卸载Win XP自带的“鸡肋”功能 Win XP以功能强大而著称,但有些功能却常常令人有“鸡肋”之感,比如Win XP自带的ZIP功能和图片预览功能,不仅占用了系统资源,功能也远不如第三方软件强大。其实用Regsvr32命令可以很容易地卸载这些功能。 在“开始→运行”中键入“regsvr32 /u zipfldr.dll”,单击“确定”按钮,弹出卸载成功信息框后就完成了ZIP功能的卸载;要恢复ZIP功能,键入“regsvr32 zipfldr.dll”即可。同样,卸载图片预览功能也很简单,在“开始→运行”中键入“regsvr32 /u thumbvw.dll”即可;如果要恢复该功能,只须键入“regsvr32 thumbvw.dll”。五、让WMP播放器支持RM格式 很多朋友喜欢用Windows Media Player(以下简称WMP)播放器,但是它不支持RM格式,难道非得安装其它播放软件吗?笔者有办法。 以Win XP为例,首先下载一个RM格式插件,解压缩后得到两个文件夹: Release(用于Windows 9x)和Release Unicode (用于Windows 2000/XP);将Release Unicode文件夹下的RealMediaSplitter.ax文件拷贝到“系统盘符/WINDOWS/System32/”目录下;在“开始→运行”中键入“regsvr32 RealMediaSplitter.ax”,点击“确定”即可。接着下载解码器,如Real Alternative,安装后就能用WMP播放RM格式的影音文件了。附录:注册和反注册dll文件的批处理dll.bat------------------------------@Regsvr32.exe AdminDLL.dllun.bat-------------------------------------@Regsvr32.exe /u AdminDLL.dll