您当前的位置: 首页 > 网站编程 > ASP教程 > 用VB生成DLL封装ASP,连接access数据库等

用VB生成DLL封装ASP,连接access数据库等

作者:guanchaofeng 来源:不详 发布时间: 2009-09-30 08:51 点击:
封装为dll会带来很多的好处,主要包括只是产权的保护,以及效率和安全性能的提升。这个例子中被封装的dll文件可以隐藏access数据库的实际路径。 VB生成的DLL封装ASP代码来连接数据库(Access)。 本文用一个最简单的连接access数据库的例子来说明如何将asp代

用VB生成DLL封装ASP,连接access数据库等

  封装为dll会带来很多的好处,主要包括只是产权的保护,以及效率和安全性能的提升。这个例子中被封装的dll文件可以隐藏access数据库的实际路径。
  
  VB生成的DLL封装ASP代码来连接数据库(Access)。
  
  本文用一个最简单的连接access数据库的例子来说明如何将asp代码封装为dll文件。
  
  我们用vb,最常见的方式来封装asp代码。
  
  我们需要封装的对象如下:
  
  'Proconn.asp
  dimProConn
  setProConn=Server.CreateObject("ADODB.CONNECTION")
  ProConn.Open"driver={MicrosoftAccessDriver(*.mdb)};uid=;pwd=123;DBQ="&Server.MapPath("DB.asp")
  
  我们将下面的部分封装
  "driver={MicrosoftAccessDriver(*.mdb)};uid=;pwd=123;DBQ="&Server.MapPath("DB.asp")
  
  分析一下这段要封装的内容,
  它的前半部分就是一个字符串:
  "driver={MicrosoftAccessDriver(*.mdb)};uid=;pwd=123;DBQ="
  用&连接上后半部分的另一个字符串。
  后半部分的另一个字符串是Server.MapPath对象函数的返回值。
  
  下面开始这个封装的操作过程。
  首先
  新建一个VB下的ActiveXDLL工程,工程的名称Project1更改成ConDBDLL
  方法class1的名称更改成cs
  工程名和方法名会在调用这个DLL的时候使用到,大家可以按照自己命名规则定义,但请注意好好使用。
  这个DLL的代码部分书写如下:
  
  DimrpAsResponse
  DimrqAsRequest
  DimapAsApplication
  DimsrAsServer
  DimsnAsSession
  
  PublicSubOnStartPage(MyScriptingContextAsScriptingContext)
  Setrp=MyScriptingContext.Response
  Setrq=MyScriptingContext.Request
  Setsr=MyScriptingContext.Server
  Setap=MyScriptingContext.Application
  Setsn=MyScriptingContext.Session
  EndSub
  
  PublicSubOnEndPage()
  Setrp=Nothing
  Setrq=Nothing
  Setsr=Nothing
  Setap=Nothing
  Setsn=Nothing
  EndSub
  '以上语句是必须的,将原本的对象作了简化处理,并在两个基本函数中作了处理
  
  PublicFunctionConnectDB()AsVariant
  ConnectDB="driver={MicrosoftAccessDriver(*.mdb)};uid=;pwd=123;DBQ="
  EndFunction
  '上面这个函数是处理前半部分字符串的,直接返回这个字符串的内容
  
  '另外定义下面这个函数来处理后半部分内容
  PublicFunctionDBPath()AsVariant
  DBPath=sr.MapPath("DB.asp")
  EndFunction
  '注意上面使用的是sr,不要使用成Server了
  
  到了关键的一步,给这个工程添加"MicrosoftActiveServerPagesObjectContextObjectLibrary"的Reference
  添加方法,选择菜单中的"Project"->"Reference",在打开的对话框里选择。
  对了,还要选择上"microsoftactiveXdataobjects2.6library"
  
  进行完以上操作,我们就可以编译生成DLL了,(别忘了前面的改工程名和方法名)
  
  准备好数据库文件DB.asp(由DB.mdb更改后缀而成,密码123)
  
  下面就是调用封装的连接数据库的asp文件代码:
  
  由于是自己创建的DLL,把它拷贝到相应的目录后,必须注册才能使用。
  注册的方法,在“运行”中执行:
  Regsvr32.exedllname.dll
  
  取消这个DLL的注册的方法是:Regsvr32.exe/udllname.dll
  
  注册完毕,我们的工作基本上就做完了,现在我们可以使用这样的封装方法连接具有针对性的数据库了。
  
  不过有一点需要特别注意的是:
  由于
  DimConDB
  setConDB=Server.CreateObject("ConDBDLL.Conn")
  'ConDB就是创建的DLL对象
  这是在ASP中创建的对象,包括ProConn,那么我们在任何使用到(引用)ProConn.asp的其他ASP文件中记得释放这两个对象!
  ProConn.close
  setProConn=nothing
  setConDB=Nothing
  否则系统会由于对象没有释放,而变得越来越不堪重负。
  
  关于这个封装ASP代码连接Access数据库的方法,我想完全适用其他数据库的连接方法。
  
  
  再例如,下面的封装的例子:
  
  首先要申明变量:
  
  PrivateWenScriptingContextAsScriptingContext
  PrivateWenApplicationAsApplication
  PrivateWenRequestAsRequest
  PrivateWenResponseAsResponse
  PrivateWenServerAsServer
  PrivateWenSessionAsSession
  
  为了在WenConnection类中使用ASP的内建对象,必须在此类中写一个OnStartPage子函数。那是因为无论什么时候用户访问一个带有本组件的ASP文件,IIS就会把ScriptingContext传送给我们的对象请我们使用。这个ScriptingContext包括了全部的ASP方法和属性,这使得我们有能力访问所有ASP的对象。
  
  PublicSubOnStartPage(PassedScriptingContextAsScriptingContext)
  SetWenScriptingContext=PassedScriptingContext
  SetWenApplication=WenScriptingContext.Application
  SetWenRequest=WenScriptingContext.Request
  SetWenResponse=WenScriptingContext.Response
  SetWenServer=WenScriptingContext.Server
  SetWenSession=WenScriptingContext.Session
  EndSub
  
  我们既然用OnStartPage函数来创建对象,那么我们这里就用OnEndPage子函数来释放对象:
  
  PublicSubOnEndPage()
  SetWenScriptingContext=Nothing
  SetWenApplication=Nothing
  SetWenRequest=Nothing
  SetWenResponse=Nothing
  SetWenServer=Nothing
  SetWenSession=Nothing
  EndSub
  
  接下来定义两个函数RsResult()和DataSource():
  
  PublicFunctionRs(strsqlAsString)AsRecordset
  DimoConnAsConnection
  DimoRsAsRecordset
  DimstrconnstringAsString
  strconnstring="driver={sqlserver};server=ServerName;uid=sa;pwd=;"&_
  "database=DataBaseName"
  oConn.Openstrconnstring
  oRs.ActiveConnection=oConn
  strsql="Select*FromtableName"
  oRs.Openstrsql,oConn,1,3
  SetRs=oRs
  EndFunction
  
  PublicFunctionDataSourceConnection()AsVariant
  DataSourceConnection="driver={sqlserver};server=ServerName;uid=sa;pwd=;database=DataBaseName"
  EndFunction
  
  三、存工程名为WenADODB.vbp和保存类名为WenConnection.cls,然后点击“文件”—>“生成WenADODB.DLL”编译成动态连接库文件。VB在编译好动态连接库文件的同时也将该组件注册到注册表里了,要是想在另外一台机器上注册该组件的话,请用以下指令注册或反注册:
  
  Regsvr32x:\路径\WenADODB.dllx:\路径\为WenADODB.dll文件存放的盘符和路径
  
  Regsvr32/ux:\路径\WenADODB.dll参数U为反注册
  
  四、在ASP文件中调用WenADODB.dll组件的例子。
  
  <%
  
  SetConn=Server.CreateObject("WenADODB.WenConnection")‘调用组件创建对象实例
  objConn=Conn.DataSourceConnection()
  application("strconn")=objConn
  
  setRs=Server.CreateObject("ADODB.Recordset")
  sql="select*fromTableNameorderbyIDDESC"
  Rs.opensql,application("strconn"),1,3
  %>
  <Tablealign="center"border="1">
  <%
  ifRs.BofandRs.Eofthen
  Response.Write"暂时还没有任何数据。"
  else
  DowhilenotRs.Eof
  %>
  <trwidth=100%>
  <tdwidth=50%><%=Rs("Field1")%></td><tdwidth=50%><%=Rs("Field2")%></td>
  </tr>
  <%
  Rs.MoveNext
  Loop
  endif
  Rs.Close;SetRs=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=PassedScriptingContext
  EndSub
  
  
  
  现在,无论什么时候用户访问一个带有本组件的ASP文件,IIS就会把ScriptingContext传送给我们的对象请我们使用.这个ScriptingContext包括了全部的ASP方法和属性.实现上,这使得我们有能力访问所有ASP的对象.看下面的代码:
  
  
  PublicSubOnStartPage(PassedScriptingContextAsScriptingContext)
  SetMyScriptingContext=PassedScriptingContext
  SetMyApplication=MyScriptingContext.Application
  SetMyRequest=MyScriptingContext.Request
  SetMyResponse=MyScriptingContext.Response
  SetMyServer=MyScriptingContext.Server
  SetMySession=MyScriptingContext.Session
  EndSub
  
  
  以后我们就能用在VB中用MyApplication来代替ASP中的Application,同理可以代替Request,Server.....,不过我们来是要在OnStartPage之前来申明这些变量:
  
  
  PrivateMyScriptingContextAsScriptingContext
  PrivateMyApplicationAsApplication
  PrivateMyRequestAsRequest
  PrivateMyResponseAsResponse
  PrivateMyServerAsServer
  PrivateMySessionAsSession
  
  
  
  使用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=Nothing
  SetMyApplication=Nothing
  SetMyRequest=Nothing
  SetMyResponse=Nothing
  SetMyServer=Nothing
  SetMySession=Nothing
  EndSub
  
  
  
  SayHello方法
  
  我们来建立一个子函数,用于显示"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文件,加一个快捷方式会减少自己的工作量:
  
  WindowsRegistryEditorVersion5.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.exeC:\Windows\System\Test.ocx
  取消注册:C:\Windows\System\Regsvr32.exe/uC:\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命令就可以轻松搞定。
  
  在“开始→运行”中键入“regsvr32actxprxy.dll”命令,点击“确定”按钮,这时会弹出一个信息对话框“DllRegisterServerinactxprxy.dllsucceeded”,点击“确定”;然后再在“开始→运行”中键入“regsvr32shdocvw.dll”命令,单击“确定”即可。重新启动后IE已经被轻松修复了。
  
  二、解决Windows无法在线升级的问题
  
  Windows的漏洞很多,每隔一段时间就需要使用“WindowsUpdate”升级程序进行在线升级,不过“WindowsUpdate”经常出现无法使用的情况,这时,我们可以使用Regsvr32来解决这个问题。
  
  在“开始→运行”中键入“regsvr32wupdinfo.dll”,点击“确定”按钮,这样在系统中就重新注册了“WindowsUpdate”组件,重新启动后问题已经解决。
  
  三、防范网络脚本病毒有新招
  
  网络脚本病毒嵌在网页中,上网时在不知不觉中机器就会感染上这种病毒。笔者认为单纯使用杀毒软件并不能有效地防范这些脚本病毒,必须从病毒传播的机理入手。网络脚本病毒的复制、传播都离不开FSO对象(FileSystemObject,文件系统对象),因此禁用FSO对象就能有效地控制脚本病毒的传播。操作方法很简单:
  
  在“开始→运行”中键入“regsvr32/uscrrun.dll”就可以禁用FSO对象;如果需要使用FSO对象,键入“regsvr32scrrun.dll”命令即可。
  
  四、卸载WinXP自带的“鸡肋”功能
  
  WinXP以功能强大而著称,但有些功能却常常令人有“鸡肋”之感,比如WinXP自带的ZIP功能和图片预览功能,不仅占用了系统资源,功能也远不如第三方软件强大。其实用Regsvr32命令可以很容易地卸载这些功能。
  
  在“开始→运行”中键入“regsvr32/uzipfldr.dll”,单击“确定”按钮,弹出卸载成功信息框后就完成了ZIP功能的卸载;要恢复ZIP功能,键入“regsvr32zipfldr.dll”即可。同样,卸载图片预览功能也很简单,在“开始→运行”中键入“regsvr32/uthumbvw.dll”即可;如果要恢复该功能,只须键入“regsvr32thumbvw.dll”。
  
  五、让WMP播放器支持RM格式
  
  很多朋友喜欢用WindowsMediaPlayer(以下简称WMP)播放器,但是它不支持RM格式,难道非得安装其它播放软件吗?笔者有办法。
  
  以WinXP为例,首先下载一个RM格式插件,解压缩后得到两个文件夹:Release(用于Windows9x)和ReleaseUnicode(用于Windows2000/XP);将ReleaseUnicode文件夹下的RealMediaSplitter.ax文件拷贝到“系统盘符\WINDOWS\System32\”目录下;在“开始→运行”中键入“regsvr32RealMediaSplitter.ax”,点击“确定”即可。接着下载解码器,如RealAlternative,安装后就能用WMP播放RM格式的影音文件了。
  
  附录:注册和反注册dll文件的批处理
  
  
  
  dll.bat
  ------------------------------
  @Regsvr32.exeAdminDLL.dll
  
  
  un.bat
  -------------------------------------
  @Regsvr32.exe/uAdminDLL.dll

分享到:
本文"用VB生成DLL封装ASP,连接access数据库等"由远航站长收集整理而来,仅供大家学习与参考使用。更多网站制作教程尽在远航站长站。
顶一下
(0)
0%
踩一下
(0)
0%
[点击 次] [返回上一页] [打印]
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 密码: 验证码:
关于本站 - 联系我们 - 网站声明 - 友情连接- 网站地图 - 站点地图 - 返回顶部
Copyright © 2007-2013 www.yhzhan.com(远航站长). All Rights Reserved .
远航站长:为中小站长提供最佳的学习与交流平台,提供网页制作与网站编程等各类网站制作教程.
官方QQ:445490277 网站群:26680406 网站备案号:豫ICP备07500620号-4