ImageVerifierCode 换一换
格式:DOCX , 页数:23 ,大小:614.38KB ,
资源ID:8589768      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/8589768.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(VB封装DLL实例讲解accessexcelword代码保护.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

VB封装DLL实例讲解accessexcelword代码保护.docx

1、VB封装DLL实例讲解accessexcelword代码保护VB封装DLL实例讲解(一讲)DLL基本概念(一)概念DLL即动态链接库(Dynamic Link Library),是由可被其它程序调用的函数集合组成的可执行文件模块。DLL不是应用程序的组成部分,而是运行时链接到应用程序中。(二)主要优点:1、多个应用程序可以共享一个DLL,而且当多个应用程序调用库的同一个函数时,可执行文件中装入的只是该函数的内存地址,从而节省内存和磁盘空间;2、使用动态链接库易于我们维护用户程序,即使对动态链接库进行修改也不会影响用户程序;3、从ACCESS角度而言,还可以更好的确保核心代码的安全。二、用VB封

2、装VBA代码,构建自定义的DLL动态链接库(一)ACCESS中实例代码下面是一个“快速获取数字(Acc).mdb”实例(该实例在文件包中),单击“提取结果”按钮,将文本框中的数字在弹出消息显示出来。我将就这个实例演示如何将该实例VBA代码封装成为DLL。 ?按钮单击事件代码如下:Private Sub CmdFindnumber_Click()Dim strM As String 初始字符串Dim strOutAs String 输出字符串变量Dim I strM = Me.Text1从第一个字符向最后一个字符循环,以提取每个字符For I = 1 To Len(strM)判断是否为0到9字符

3、,是则赋值输出 If Mid(strM, I, 1) Like 0-9 Then strOut = strOut & Mid(strM, I, 1) End IfNext I用MsgBox函数进行输出测试MsgBox strOutEnd Sub M以上代码还不能直接用于封装,须将其修改成为公用函数(过程)(二)VB封装实例中VBA代码步骤一:在VB编辑窗中,点菜单【文件】-【新建工程】,打开新建工程窗口步骤二:修改工程名,这即生成的DLL库名 1、修改工程名为:我的动态库步骤三:修改类名1、改类名为:提取数字步骤四:在代码窗口输入如下代码。将ACCESS中的单击事件代码,略做修改成为一个公用函

4、数,然后复制到VB代码编辑窗口?代码如下将这前的ACCESS代码改成一个公用函数输入:strPutString 字符串变量,需分离数字的字符串输出: fFindNumber字符串变量,得到的数字字符Public Function fFindNumber(strPutString As String) As String Dim strOutAs String 输出字符串变量 Dim I 从第一个字符向最后一个字符循环,以提取每个字符 For I = 1 To Len(strPutString) 判断是否为0到9字符,是则赋值输出 If Mid(strPutString, I, 1) Like

5、0-9 Then strOut = strOut & Mid(strPutString, I, 1) End If Next I数字输出 fFindNumber = strOutEnd Function步骤五:编译DLL,点菜单【文件】-【生成我的动态库.dll】,VBA代码封装DLL就完成了。三、在mdb中调用自定义DLL动态链接库(一)新建数据库及窗体新建【快速提取数字(DLL)实例.mdb】数据库,新建一个窗体【frmMain】,在窗体添文本框【text0】,按钮【CmdFindNum】,Caption属性:“提取数字”(见下图)(二)引用【我的动态库.dll】库按【Alt+F11】打开

6、VBE窗口,点菜单【工具】-【引用】,打开引用对话框,完成对我们自己编译的DLL的引用。(三)在【CmdFindNum】按钮单击事件中加入如下代码。Private Sub CmdFindNum_Click()申明自定义类Dim MyFindNum As 提取数字Dim strOut As String 实例化提取数字类对象Set MyFindNum = New 提取数字将函数输出结果赋值给自定义字符串变量strOut = MyFindNum.fFindNumber(Text0) 在消息框中显示MsgBox 你提取的数字为: & strOut, vbInformation, 江羽提示:End S

7、ub点击保存后,你就可以运行一下窗体测试你的成果了M本文实例见实例包,下载测试如果提示错误,请重新对自定义类库进行引用。本 文只是通过一个简单的实例演示了,如何通过VB封装一般的VBA中代码,因为该代码中并未涉及到ACCESS应用程序对象,所以在VB中没有对 ACCESS对象类库进行引用,另外实例中只是简单演示了,如何手动实现对DLL的注册引用,在后续文章中我将就如何实现DLL与ACCESS应用程序对 接及DLL的自动注册及引用结合实例进行讲解。VB封装DLL实例讲解(二讲)上文中我们已经就DLL的基本概念,以及如何将VBA代码封装为DLL,如何引用该生成的DLL动态链接库,进行了初步的讲解,

8、我想大家对于VB封装DLL应该有了一个初步的了解。下面主要就DLL如何实现对ACCESS对象进行封装方法进行探讨。一、如何在VB中实现对ACCESS对象编程(一)在VB中引用ACCESS对象类库我们要通过编译DLLACCESS对象的封装,首先必须在VB中引用ACCESS对象类库,这样我们就可以在VB中,实现对ACCESS应用程序中的对象进行编程。来实现对打开VB编辑窗口,点菜单【工程】-【引用】,打开【引用对话框】,点选“Microsoft Access 11.0 Object Library”完成对当前版本ACCESS应用程序对象的引用。(实例演示版本为ACCESS 2003)M对ACCES

9、S对象库的引用很关键,否则我们无法实现对ACCESS对象的编程(二)了解ACCESS对象模型在VB中要对ACCESS对象进行编程,还必需对ACCESS所提供的各项对象有一定了解,因为VB就是通过ACCESS对象的方法与属性,来完成各项操作与设置,下图为ACCESS 2003 的对象部分模型图例。 P上图为ACCESS 2003对象模型,因为篇幅的问题,文中只显示模型中部分对象,要了解全部对象模型,请大家参阅帮助。(三)VB编程中ACCESS VBA与VB对象表述区别1、ACCESS VBA与VB的顶层对象都为Application ,但在编程中ACCESS VBA顶层对象表述为:Applica

10、tion,而在VB编程中顶层对象用简写:App表述(到VB.NET又改回了Application)。?例程:在VB编程中获得VB及ACCESS VBA获取当前路径实例:在VB中获得当前路径:App.Path在VB中获得ACCESS的当前路径:Application.CurrentProject.PathP在office各应用程序之间调用各组件时,通常在对象前加上库名,如:Access.Application来表述,但因为VB与ACCESS顶层对象原本表述就存在区别,在VB中可以直接用Application表述ACCESS应用程序对象,并不会产生冲突的问题。2、ACCESS VBA和VB中部分预

11、定义类对象(如:窗体、控件等)表述基本相同,以“标签控件”为例,VB与ACCESS VBA均为Label,在VB编程中为了与ACCESS预定义类对象加以区别,ACCESS标签对象通常用ACCESS.Label表述。?例程:在VB编程中定义VB及ACCESS标签控件对象实例:在VB中定义VB标签对象:Dim m_Label As Label在VB中定义ACCESS标签对象:Dim m_Label As Access.LabelM在进行DLL编程时,特别需注意对象表述区别的问题,否则无法编译或是编译后在ACCESS调用中报错。(四)VB编程中关于ACCESS VBA专属常量ACCESS VBA专属

12、常量以“ac”开头,如:控件类(AcControlType)中的文本控件常量为acTextBox,这些常量不一定能被VB所识别,解决办法通常不使用“常量名”,而直接使用“常量值”,或以输入参数方式传递的方法来解决。?例程:实现隐藏所有文本控件。acTextBox常量值为109。Dim ctlAs Access.Control 申明ACCESS控件对象Dim frmClt As Access.Controls 申明ACCESS控件集合遍历所有ACCESS控件集合,如为文本控件,则不显示该控件For Each ctl In frmClt.Controls 文本控件类常量值为109,以常量值替代ac

13、TextBox常量名 If ctl.ControlType = 109 Then ctl.Visible = FalseNextP 你可以通过帮助查阅ACCESS专属常量值,也可以在ACCESS VBA中通过程序方式获取,如:在立即窗口输入:?acTextBox回车,就可以acTextBox常量值为:109。二、DLL封装ACCESS对象实例演示(一)ACCESS的MDB实例MDB实例演示获得ACCESS版本信息,并在标签Label0中显示(见下图),具体参看实例中frmVer6窗体中的代码,及类模块ClsVeresion中代码。Pmdb实例中frmVer1-frmVer6各窗体中具体演示了,

14、代码按DLL封装需要整理的思路。?例程:frmVer6窗体加载事件代码 Private Sub Form_Load()申明自定义类的实例Dim m_Ver As New ClsVeresion 调用自定义类的objAddItem方法 m_Ver.objAddItem Label0 End Sub ?例程:ClsVeresion类模块代码 程序功能:定义类接口,将版本信息输出并在标签中显示Public Sub objAddItem(m_label As Label) m_label.Caption = AppVersionEnd Sub函数功能:输出ACCESS版本信息Private Funct

15、ion AppVersion() As String Dim strVer As String 定义字符串变量 将版本号赋值给字符串变量 strVer = Application.Version根据版号输出对应版本信息 Select Case strVer Case 8.0 AppVersion = Access 97 Case 9.0 AppVersion = Access 2000 Case 10.0 AppVersion = Access 2002 Case 11.0 AppVersion = Access 2003 Case 12.0 AppVersion = Access 2007

16、End SelectEnd Function (二)DLL的封装ACCESS对象实现1、打开VB6.0编辑器,点菜单【新建工程】,在【新建工程】对话框中,点选【ActiveX DLL】,点【确定】。 2、修改工程名及类名,实例中我定义的工程名:GetAccVer ,类名:ClsAccVer ,修改完成以后点选菜单【保存】工程 (见下图)。P工程名就是我们后面将引用的DLL库名,类模块名为代码中我们申明的类名。3、点菜单【工程】-【引用】,打开【引用对话框】,点选“Microsoft Access 11.0 Object Library”完成对当前版本ACCESS应用程序对象的引用。4、将MDB

17、中类模块ClsVeresion代码复制到VB中ClsAccVer类模块中,按前面我们所述的VB中实现ACCESS对象编程的注意要点略做修改。(见下图划红线部分)P1、因为VB与ACCESS VBA 中标签类对象都为Label,因此加上库名(Access.Label)加以区别; 2、因为VB与ACCESS VBA顶层应用程序对象,表述原本就有区别,所以无需特别区分。?例程:ClsAccVer类模块代码 程序功能:定义DLL接口,将版本信息输出并在标签实例中显示Public Sub objAddItem(m_label As Access.Label) m_label.Caption = AppV

18、ersionEnd Sub函数功能:输出ACCESS版本信息Private Function AppVersion() As String Dim strVer As String 定义字符串变量 将版本号赋值给字符串变量strVer = Application.Version 根据版号输出对应版本信息 Select Case strVer Case 8.0 AppVersion = Access 97 Case 9.0 AppVersion = Access 2000 Case 10.0 AppVersion = Access 2002 Case 11.0 AppVersion = Acce

19、ss 2003 Case 12.0 AppVersion = Access 2007 End SelectEnd Function4、编译DLL,点菜单【文件】-【GetAccVer.dll】动态链接库,封装DLL就完成了。你现在可以在ACCESS中引用该DLL测试一下看看成果了。参看实例中frmVer7窗体,如实例引用报错,请重新引用GetAccVer.dll即可。 因为受本人认知及文字水平所限,不免有错漏之处,还请大家斧正。本文的Word文稿、VB源码、MDB实例均在“实例包”中。在后文中我们主要就动态链接库引用的方法和技巧结合实例进行探讨。VB封装DLL实例讲解(三讲)一、手动注册及引用

20、(一)手动注册及引用方法(参看实例:手动引用.mdb)进入VBA编辑窗口,点菜单【工具】【引用】,打开【引用】对话框,点【浏览】按钮,打开【添加引用】对话框,点选要引用的DLL(测试实例为:ClsFindString.dll),点【打开】点【确定】,我们完成动态链接库的手动注册及引用。(二)手动注册及引用方法不足及问题手动注册引用优点是不言而喻的,方便简捷,易于操作。但在实际运用中,当我们在其他电脑上发布应用程序,或运行我们测试好的应用程序时,却会出现错误提示,程序无法正常运行。错误(一):找不到工程或库(见下图)错误的主要原因:DLL在当前运行的电脑系统中没有注册信息,而且引用不正确。错误(

21、二):引用的动态链接库(DLL)丢失(见下图)进入到VBA编辑窗口,点菜单【工具】【引用】,打开【引用】对话框,我们会看到之前引用的DLL动态链接库丢失。错误的主要原因:系统无法找到原路径引用DLL。错误(三):自动化错误(见下图)错误的主要原因:我们在发布应用程序的电脑或系统中,虽然重新完成DLL手动注册和引用,但如果DLL路径再次改变,运行程序时就会出现“自动化错误”提示。错误(四):ActiveX部件不能创建对象(见下图)错误的主要原因:应用程序已正常引用DLL动态链接库,但其册注信息丢失或者没有正常注册,就会出现以下问题。(三)解决上述错误方法1、解决错误方法,当然是重新进行DLL的手

22、动注册及引用,具体步骤参下图。但这只是治标不治本的办法,不利于对外发布我们的应用程序,最好的办法还是通过VBA自动完成DLL的注册及引用。二、自动注册及引用方法在探讨如何实现DLL自动注册及引用之前,我们必须清楚一点,那就是DLL的注册与引用并不是同一事件或行为的两种不同表述,而是两种不同的动作。 DLL注册是指将DLL的相关信息,如:DLL唯一识标号(GUID),版本号(Version)及路径(Path)信息写入注册表中,以供系统对DLL进行识别调用。我们通过VB编译生成DLL时,VB一般会自动完成对该DLL的注册,但如果要在其它电脑上运行程序时,我们就必须重新对该DLL进行注册。 DLL引

23、用是指将DLL类库对象集成到代码编辑环境中,以便编程时调用类库中的对象、属性及方法。我们通过手动方式完成DLL的引用时,系统会自动完成对该DLL的注册,所以我们无需另行对DLL进行注册,但如果我们在其它电脑上运行程序时,还会出现我们在之前章节中所述的错误。(一)DLL自动注册方法我们可以通过 Regsvr32.exe 来进行DLL注册或反注册,具体的语法及参数:语法:Regsvr32 /u /n /i:cmdline dllname说明:其中dllname为DLL文件名,建议在发布时将DLL复制到system文件夹下。参数:参数说明/u反注册/s指定regsvr32安静运行,且不显示任何消息框

24、。/n指定不调用DllRegisterServer。此选项必须与/i共同使用。/i:cmdline调用DllInstall 将它传递到可选的 cmdline。在与/u共同使用时,它调用dll卸载。dllname指定要注册的dll文件名。1.1 示例通过Shell运行Regsvr32程序完成DLL注册 Shell Regsvr32 /S & Chr(34) & CurrentProject.Path & ClsFindString.dll & Chr(34)Shell 函数 用以运行Regsver32程序Regsver32 注册程序/S 注册程序参数,书写时记得参数前后必须留空Chr(34) C

25、hr函数,获指定代码字符,Chr(34)为引号CurrentProject.Path DLL当前路径ClsFindString.dll 演示实例DLL名1.2 示例通过Shell运行Regsvr32程序反注册Shell Regsvr32 /U /S & Chr(34) & CurrentProject.Path & ClsFindString.dll & Chr(34)我 们可以将注册语句放在窗体的加载事件,自动完成DLL的注册,具体可以参看实例。但如果我们有多个DLL需要批量注册时,可以考虑通过软件打包发布工具来 完成DLL的注册工作;也可以事先编写BAT文件,在打包发布时将该BAT文件一并

26、打包发布,安装时运行该BAT文件,来完成N个DLL的批量注册,在此 就不多着笔墨,大家可以参看实例包中的BAT文件实例。(二)DLL自动引用方法2.1 通过References对象的AddFromFile方法实现自动引用Dim ref As Reference申明引用类对象On Error Resume Next 避免因重复引用造成的错误提示实例化引用对象,完成DLL的引用Set ref = References.AddFromFile(CurrentProject.Path & ClsFindString.dll)为了避免因重复引用出现的错误,我们可以如上代码中加入Error语句,我们还可以

27、在应用程序退出时,通过对References 对象的Remove 方法释放DLL或反引用。Dim ref As Reference申明引用类对象实例化反引用对象Set ref = References(ClsFindString)移除引用指定类库References.Remove ref说明:根据本人实践,我个人倾向于使用Error语句,因为如果应用程序非正常退出,引用对象没有反引用成功,启动时就难免出现重复引用的错误问题。2.2 通过DLL唯一标识号实现自动引用Dim ref As Reference 申明引用类对象On Error Resume Next避免因重复引用造成的错误提示唯一标识号完成注册,需要DLL标识号,主版本号,次版本Set ref = References.AddFromGuid(C5E340E2-C557-4852-AE83-5A0578B6863B, 1, 0)DLL的标识号是编译生成时就确定了的,这个标识号就是DLL的终生制身份证号,我们可以通过这个唯一标识号来完成DLL自动引用。但此种方法必须具备两个条件,一是DLL已经成功注册,二是我们知道了该DLL的标识号、主版本号、次版本号。2.2.1获取DLL标识号、主版本号、次版本号方法Dim ref As Reference 申明引用类对象实例化引用类库对象Set ref = Refer

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1