.Net调用Com组件主要分为两类:静态调用及动态调用。所谓静态调用:指经过tlbimp.exe命名产生Com组件在.Net环境下的包装类,而后经过这个包装类来访问Com组件。所谓动态调用:是指不经过Com组件的包装类来进行Com组件调用,而是在远行时经过反射来进行Com组件调用。c#
下面将分别详细的讨论这两种实现方法:工具
静态调用ui
一、 编写Com组件MyComponent.dllspa
二、 产生可访问Com组件的包装类:.net
tlbimp /out:Interop.MyComponent.dll MyComponent.dllcode
三、 在.Net代码中访问对象
只要在项目添加Com包装类,就能够像访问.Net的装配件同样访问Com组件。string
固然上面的三个步骤也能够在VS中直接添加对Com组件的引用,让VS自动完成第二步。object
注意:file
一、 若是引用Com组件的.Net项目为结果为强命名组件,这个时候要求Com组件的包装类也必须为强命名组件,因此这个时候必须手动进行第二步操做,而且在产生包装类的时候设置snk文件名称,具体操做方法为:
tblimp /keyfile:filename.snk /out:Interop.MyComponent.dll MyComponent.dll
二、 要想有更多的设置请参考tlbimp的使用方法。
动态调用
一、 编写Com组件MyComponent.dll。
二、 在.Net程序中产生要被调用的Com组件类的Type:
Type comType = Type.GetTypeFromCLSID( Guid ); 或
Type comType = Type.GetTypeFromProgID( string );
三、 生成Com组件类对象
object comObj = Activator.CreateInstance( comType ); 或
object comObj = comType.InvokeMember(null,
BindingFlags.DeclaredOnly |
BindingFlags.Public | BindingFlags.NonPublic |
BindingFlags.Instance | BindingFlags.CreateInstance,
null, null, args );
四、 设置参数及其对应的ByRef属性。
object[] args = new object[]{arg1, arg2 , …,argn};
ParameterModifier[] modifiers = new ParameterModifier[1];
modifiers[0] = new ParameterModifier( argNumCount );
//设置参数是否为ByRef
modifiers[0][0] = true;//表示该参数是ByRef(InOut/Out)
modifiers[0][n] = false;//表示该参数是ByValue(In)。
五、 调用Com组件方法或者属性。
object returnValue = comType.InvokeMember(
“MethodName”,indingFlags.InvokeMethod,null , comObj ,args ,modifiers ,null );
注意:
一、 调用Com组件方法的时候,不可以采用MethodInfo的方式进行调用,因为没有Com组件的源数据信息,不能经过Type.GetMethod等方法够获取与Com组件相关的任何特有类型信息。
二、 动态调用Com组件方法中,若是须要参数回传值,则必须将该参数对应的ParameterModifier表示设置为True,即便该参数类型为传址类型。(在.net中若是参数为传址类类型,那么参数默认行为是ByRef的)。
c#建立组件
a) 工程属性→应用程序→程序集信息→勾选“使程序集COM可见”
b) 工程属性→生成→勾选“为COM互操做注册”
c) 不能使用静态类、静态方法
d) 参数仅使用基本类型,如string、int
注册装配件 RegAsm /codebase MyService.dll
注意:/codebase是指设置注册表中的基本代码,也就是记录下dll的路径,供ccw在Com客户端在任何位置均可以找到该dll,若是没有/codebase属性,则默认为dll在Com客户端执行程序的当前目录下面。
工具用法:
将COM对象转换为.NET程序集
//TlbImp.exe /out:Interop.XX.DLL /namespace:Interop.XX
将普通dll导出为TXT文件
//dumpbin.exe /exports xx.dll >file.txt