[C#]利用反射调用COM组件

时间:2022-08-30 18:04:23
  最常见的调用com组件的方法就是添加对这个组件的引用,但是这会在最终可执行文件边生成一个伴随的dll如MyCom.Interop.dll等,这给程序的分发带来相当程度的不便,而且添加引用是我们只能引用某个特定版本的com组件,而我们往往无法确定程序所运行的机器上是否有相应版本的com组件,这可能造成我们的程序无法运行。我们要如何解决这个问题呢?
  首先要解决com组件的版本问题,这就要求我们不直接使用clsid,而用ProgId来代替客户机上的com组件就可以解决相当程度的问题了,就是这么简单。
  至于如何才能把那个可恶的dll文件给去掉,这就需要利用dotNet提供的反射功能了,我们一代码为例,这里我们假设有一个ProgId为"ReflectionCom.TestObj"的com组件,这个组件有唯一一个方法string SayHello(string AName):
[C#]利用反射调用COM组件using  System;
[C#]利用反射调用COM组件
using  System.Reflection;
[C#]利用反射调用COM组件
[C#]利用反射调用COM组件
namespace  TestConsole
[C#]利用反射调用COM组件[C#]利用反射调用COM组件
{
[C#]利用反射调用COM组件    
class MainEntryPoint
[C#]利用反射调用COM组件[C#]利用反射调用COM组件    
{
[C#]利用反射调用COM组件        
static void Main(string[] args)
[C#]利用反射调用COM组件[C#]利用反射调用COM组件        
{
[C#]利用反射调用COM组件[C#]利用反射调用COM组件            
object[] oParams = new object[] "leafyoung" };
[C#]利用反射调用COM组件            
object oComObj = Activator.CreateInstance(
[C#]利用反射调用COM组件                Type.GetTypeFromProgID(
"ReflectionCOM.TestObj"));
[C#]利用反射调用COM组件            
object rez = oComObj.GetType().InvokeMember("SayHello",
[C#]利用反射调用COM组件                BindingFlags.InvokeMethod,
[C#]利用反射调用COM组件                
null,
[C#]利用反射调用COM组件                oComObj,
[C#]利用反射调用COM组件                oParams);
[C#]利用反射调用COM组件            Console.WriteLine(rez);
[C#]利用反射调用COM组件        }

[C#]利用反射调用COM组件    }

[C#]利用反射调用COM组件}
  行了,我们就是怎么简简单单就可以调用com组件的任何功能了。
  不过我们要看到这种方法的不足,由于这里用了迟绑定,因此我们无法让编译器做任何的类型检查工作,因此只有在运行时才能知道程序对错;而且,可以以这种方法调用的com组件必须实现IDispatch接口,也就是说必须是一个自动化组件,假如你要调用的组件是一个普通的com组件的话,那就一边哭去吧!呵呵