当用.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以上是官方解释得PIA,说白了就是微软提供的用于使用其产品特性的一些公共数据定义和方接口,这些特性中就包括VBA模块,当然还有其他的特性,对于ACCESS有数据查询,排序,等等,这里讲的仅仅是应用其中VBA模块特性的方法。首先需要导入Microsoft.Office.Interop.Access程序集主程序代码如下:
posted on 2009-02-10 14:01 pear_li 阅读(2064) 评论(0) 编辑 收藏 引用 所属分类: C#/.net