C#中调用COM对象

开发 后端
本文介绍要想C#调用COM对象的方法、函数和属性,就必须使用包含正确设置的Type对象的InvokeMethod()方法。

.NET框架是COM的一个自然发展,两者共享许多核心要素,这包括组件的再利用以及语言的中立性。为了向后兼容,COM Interop可以使用现存的COM组件而不要求对原始组件进行修改。当一个 .NET 框架开发人员想将COM代码合并到一个管理应用程序中时,就可以用COM Interop功能引入相关的COM类型。引入之后,这个COM类型就可以使用了。这属于前期连接。但是有时候你需要对象的后期连接,这在.NET中也能实现,使用名称空间映射就可以通过后期连接来C#调用COM对象。

这里介绍一个应用程序例程,它将调用Excel,并且通过使用后期连接使它可视。
后期连接将使用Reflectionb的Type类,这个Type类有许多方法可以取得COM对象,就象我们已经使用过的 GetTypeFromProgID("Application"),这个方法从系统注册表中得到COM ID,然后使用STATIC类的成员 Activator.CreateInstance()创建这个COM对象的一个新例示。

要想C#调用COM对象的方法、函数和属性,就必须使用包含正确设置的Type对象的InvokeMethod()方法。这个方法接受一些参数变量,其中最重要的一个是方法类型的ex属性(get或set)。在例子中我们为Excel.Visible使用了set属性,从而使Excel应用程序可视。

我们将尝试在.NET环境中调用Excel应用程序。这是一个后期连接应用程序,因为如果是前期连接的话你就需要使用COM对象的RCW(RunTime Callable Wraper:运行时间的可调用包)来完成下面的命令行程序tblimp所完成的任务:

  1. //Variable  
  2. Type excel;  
  3. object[] parameternew object[1];  
  4. object excelObject;  
  5. try{  
  6. //Get the excel object  
  7. excel = Type.GetTypeFromProgID("Excel.Application");  
  8. //Create instance of excel  
  9. excelObject = Activator.CreateInstance(excel);  
  10. //Set the parameter whic u want to set  
  11. parameter[0] = true;  
  12. //Set the Visible property  
  13. excel.InvokeMember("Visible", BindingFlags.SetProperty, null, excelObject, parameter);  
  14. }  
  15. catch(Exception e){  
  16. Console.WriteLine("Error Stack {0} ", e.Message) ;  
  17. }  
  18. finally{  
  19. //When this object is destroyed the Excel application will be closed  
  20. //So Sleep for sometime and see the excel application  
  21. Thread.Sleep(5000);  
  22. //Relaese the object  
  23. //GC.RunFinalizers()  
  24. }  

本文介绍C#调用COM对象。

【编辑推荐】

  1. 浅谈C#中构造函数和成员函数
  2. C#函数的参数返回结构数组
  3. 概述ASP.NET中的NGWS Runtime
  4. C#函数与JavaScript函数
  5. 详解C# Object.Equals函数
责任编辑:佚名 来源: 51CTO.com
相关推荐

2009-08-21 17:45:40

C#调用COM对象

2009-08-05 15:10:19

C#调用GoogleE

2009-08-10 13:40:46

创建C# COM对象

2009-09-02 16:43:55

C#调用Excel的C

2009-08-10 13:34:11

创建C# COM对象

2009-09-24 15:10:54

C#调用COM组件

2009-08-17 13:49:20

C#中调用Window

2009-09-02 16:36:37

C#调用Excel对象

2009-09-18 19:09:41

C# COM组件

2009-08-19 14:35:12

C++和C#相互调用C

2009-09-02 14:18:08

C#声明COM接口

2009-08-20 11:03:34

Visual C#使用

2009-08-11 14:26:56

C#动态调用WebSe

2009-08-03 14:36:08

c#组件

2009-08-17 16:18:47

C#调用CreateO

2009-08-10 14:03:08

C# COM接口

2009-08-21 09:14:47

C# Excel CO

2009-08-11 10:12:21

2009-08-28 16:50:25

C# PromptPo

2009-08-20 17:13:37

C# FileSyst
点赞
收藏

51CTO技术栈公众号