前端之家收集整理的这篇文章主要介绍了
在VB中怎么实现COM+,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
终于试验成功了! 我在原本只有win2000 professional 的机器上又安装了一个win2000 server,并将其配置成主域 控制器,然后在另一台win98机器上用Administrator
登录,启动VB,写个
小程序试了一下,OK! 为避免大家继续在黑暗中摸索,我现将试验用的具体例子及步骤详述如下(一个最简单的例子): 1、在win2000 server机器上用VB(+SP5.0)创建一个ActiveX(DLL)工程,将工程名字改为“COM_Test” 2、
添加一个类模块,
名称为“ClsAdd”,并输入如下几行
代码: Option Explicit Public x,y As Integer Public Function myAdd() As Integer myAdd = x + y End Function 3、打开“工程
属性”对话框,选择“
生成”,选中“
自动升级”;选择“部件”,选中“远程服务器
文件”(此点很重要,否则编译时不会
生成类型库
文件COM_Test.TLB)及“二进制兼容”,最后“确定” 4、保存并编译,
生成“Com_Test.dll” 5、打开“控制面板/管理/组件服务”,在“COM+应用程序”下利用“COM+应用程序安装向导”创建一个空的COM+应用程序,
名称为“MyTest” 6、在“MyTest”下,新建“组件”,在“组件安装向导”中,选择“安装新组件”(注意:不要使用“导入已被
注册的组件”),然后将第4步
生成的Com_Test.dll及Com_Test.tlb都
添加进来(两个
文件都要!),完成。 7、右击“COM+应用程序”上方的“我的电脑”,选择“
属性”,然后在“
属性”对话框中的“默认
属性”页下,将“默认身份验证级”改为“无”,确定。 8、右击“MyTest”,导出客户端的“应用代理”。注意:在导出对话框中,必须选择“应用程序代理”而不是“服务器应用程序”! 9、将导出后的两个
文件(即应用程序代理)安装到win98机器上,此时它会在
注册表中
添加几处
注册项,并在C:\program files\ComPlus Applications下产生一个以CLISD命名的
文件夹,打开来可看到Com_Test.tlb及Apl82.tmp二个
文件。 注意:win98机器上是没有Com_Test.dll
文件的,该
文件在win2000 server机器上! 好了,准备工作至此结束,下面在win98机器上来验证你的COM+配置型组件能否工作。(先用Administrator及口令
登录) 10、启动VB(+sp5.0),创建一个exe工程,在窗体上放置一个文本框与一个命令按钮,并在命令按钮的Click事件中加入
代码: Dim ox as object set ox=createobject("Com_Test.ClsAdd","win2000 server 的IP地址") ox.x=12 ox.y=13 text1.text=ox.myAdd() 执行程序,win2000 server 机器的硬盘灯一阵闪烁之后,Text1中欢快地跳出“25” ---成功了! 以上经验是在我经过多次痛苦的失败之后摸索出来的,看来靠别人不如靠自己。 后记: 1、此前,我对有关COM+的
内容可以说是一片空白,什么都不懂,甚至也没做过有关DCOM的试验。近来空闲,络续看了点CSDN论坛中的提问与回答,可没有一个让人满意的。万不得已,自力更生。 2、个人以为,COM+组件并不一定要配置在主域控制器上,但必须配置在某个域中的某台win 2000 Server上,而不是一般的2000 professional上(可能考虑到安全性)。 3、配置COM+组件不是在win98机器上的,而是在win 2000 Server上。比如,你在win98机器上安装 应用程序代理后,找不到相应的DLL
文件,只有TLB
文件(类型库),该DLL
文件在win 2000 Server上由Dllhost.exe来负责装入内存。 4、若是创建非配置型组件,则第一步中不是创建一个ActiveX(DLL)工程,而是ActiveX(EXE)工程,因为该exe
文件在服务端不是由Dllhost.exe来负责装入内存,而是自行执行。此种情形下,当然也 就不需要第5至9步的操作了。