当用.NET调用已有的COM组件的时候,一般需要使用tlbimp导入COM组件的TypeLibrary信息,生成对应的Interop Assembly。所谓PIA (Primary Interop Assembly),则是“官方”发布的对于某个COM组件的.NET DLL。比如微软公司发布了Office 2003的COM组件,可以用于操作COM,同时,微软也发布了Office 2003所对应的PIA,用于.NET。PIA和普通的Interop(又称为AIA, Alternative Interop Assembly)的不同之处在于:

1.     PIA是官方发布并经过Sign,可以在不同程序中共享。而AIA如果被不同的公司Sign过,则一个公司Sign的AIA DLL所创建的对象和另外一个公司Sign的AIA DLL是不兼容的(不同的Key代表不同的Identity),这也是使用PIA的主要原因

2.     PIA可能经过某种改动使其比一般Tlbimp生成的Interop DLL要容易使用一些,比如提供一些封装函数。修改方法通常有两种:

a.     可以从Tlbimp生成的DLL反汇编修改再生成新的DLL

b.     可以自己用C#来编写这个DLL(其实Tlbimp和Tlbexp也是C#写的)

3.     用Tlbimp生成PIA的时候需要指定/primary开关并声明对应的key,如果不使用tlbimp生成PIA,则需要将对应的DLL加上PrimaryInteropAttribute和GuidAttribute,这也正是Tlbimp所作的。

4.     用RegAsm注册PIA的时候,RegAsm会在COM组件的TypeLibrary注册项中加入注册信息表明该PIA对应这个COM组件

5.     当用Visual Studio的Add Reference功能的时候,VS会自动去查找是否有符合条件的PIA(通过上面所说的注册信息),如果存在,则直接使用这个DLL


 

作者:      ATField