在ASP.NET中使用非托管COM组件(2)
发表于:2007-06-30来源:作者:点击数:
标签:
3、IL反汇编(Disassembler) 现在基本上到了令大多数 VB 或VBScript 程序员 头疼的时候了,我们要利用一个反汇编器产生一些重要信息。 Assembly 的名称空间(使用 @Import 语句) 精确的类名(这可能与ASP有着很大的不同!) 方法和属性的数据类型 方法和属性的
3、IL反汇编(Disassembler)
现在基本上到了令大多数
VB或VBScript
程序员头疼的时候了,我们要利用一个反汇编器产生一些重要信息。
Assembly 的名称空间(使用 @Import 语句)
精确的类名(这可能与ASP有着很大的不同!)
方法和属性的数据类型
方法和属性的精确拼写。注意在 C# 中 Bodytext 和 BodyText是两个完全不同的变量。
产生上述信息需要使用IL (Intermediate Language) Disassembler中间语言反汇编器,你可以在生成元数据后,并把它们移动到适当目录后直接键入ildasm.exe激活这个命令。然后可以利用File | Open,选择相应的文件,显示的结果如下图所示,显示的结果非常类似于OLE/COM查看器获得结果。
[htmChina:ImageAlign align=center][htmChina:Image id=Image1|2][/htmChina:Image][/htmChina:ImageAlign][htmChina:ImageAlign align=center][htmChina:Image id=Image1|3][/htmChina:Image][/htmChina:ImageAlign]
注意生成的汇编文件不一样,名称空间的名称也不一样,在ASP.NET页面往往需要使用 @Import 导入名称空间,不过它们的类、属性、方法都是一样的。对于ASP
.net程序员来说,整个蓝色的符号都是很重要的,因为它们表示的是一个类或者是一个接口。如果我们对这些类或者接口进行展开,我们会获得一系列属性和方法的列表。
我们看到的所有方法都有一个精确的数据类型描述。首先是方法名称,冒号后面是返回值类型圆括号中是方法需要的参数。
当我们谈及用get_ 和set_方法描述属性的时候,VBScript程序员可能会一头雾水,我们知道每一个属性实际上是对应于类中的一个私有成员,属性的读写分别是通过这两个函数实现的。
[htmChina:ImageAlign align=center][htmChina:Image id=Image1|4][/htmChina:Image][/htmChina:ImageAlign]
每一个属性旁边都有一个红色的标记,双击这个属性,我们可以获得属性的定义,我们可以看到属性可以为Get, Set 或者 Get/Set。
4、组件的使用
当我们对元数据了解清楚以后,剩下的工作就是如何在ASP.NET 中使用这个组件,下面是一段使用MsAgent的代码:
<% @Page Language="C#" %>
<% @Import Namespace="AgentObjects" %>
<%
AxAgentObjects.AxAgent AxAgent=new AxAgentObjects.AxAgent();
IAgentCtlCharacterEx Character;
AxAgent.Characters.Load("Genie",(object)"GENIE.ACS");
Character = AxAgent.Characters["Genie"];
Character.LanguageID = 0x409;
// Display the character.
Character.Show(null);
Character.Speak(“Hello World”, null);
Response.Write(Character.Name);
Character.Play("Wave");
Character.Play("Hide");
%>
当导入类型库以后,接着我们要创建这个类的实例,剩下的使用方法基本上和ASP应用组件差不多。
所有的COM组件调用的方法基本上相同,正如在托管应用程序(C#、Visual Basic.NET)加入一个COM组件引用,接着系统要为这些非托管代码生成一个封装,实际上也是执行上面的步骤,即导入类型库。实际上这种方法可以用于所有的托管应用程序中,包括托管的C++代码、C#、Visual Basic.NET环境,.NET 框架的这种互操作性保护了组件
开发者的既有投资,而且为我们的托管程序设计提供了一条思路。即我们可以把许多使用托管代码难以实现或者实现起来非常麻烦的功能(比如通过API函数调用读写软盘硬盘物理扇区)封装到一个非托管的COM组件中,通过组件调用间接实现。
原文转自:http://www.ltesting.net