12

使用 VS 2008,这是我的 COM 对象

using System;
using System.Collections.Generic;
using System.Text;
using System.Runtime.InteropServices;
using System.Windows.Forms;

namespace TestCom
{    
    [Guid("9E5E5FB2-219D-4ee7-AB27-E4DBED8E123E")]
    [ClassInterface(ClassInterfaceType.AutoDual)]
    [ProgId("Test9.COMINT")]
    public class TestComClass  
    { 
        public void Init(string userid, string password)
        {
            MessageBox.Show(string.Format("{0}/{1}", userid, password));
        }       
    }
}

如果我构建它并在生产机器上注册它,如下所示

REGASM /CODEBASE TESTCOM.DLL

从一个简单的 VB6 应用程序可以正常工作

Private Sub Form_Load()
  Dim o As Object
  Set o = CreateObject("Test9.COMINT")
  o.Init "A", "B" 
End Sub

在 Excel 中从 VBA 调用的完全相同的代码给出

“自动化错误”(0x80131700)

在开发机器上一切正常,只是在安装了 .NET 和 MS Office 的生产机器上不行。

更新

我认为这与在 Excel 下运行时未正确初始化的 .NET 框架有关。如果我使用 Filemon,我可以看到它四处寻找 MSCORWKS.DLL。当我从 VBScript 调用同一个对象时,它发现 MSCorwks.dll 很好。

当我从 VBA 调用以尝试强制加载 CLR 时,有趣的是,我得到的结果与我在 VBA 中所做CorBindToCurrentRunTime的完全相同。HRESULT (0x80131700)CreateObject()

因此我认为这是一个框架初始化问题。

4

5 回答 5

13

我将回答我自己的问题,希望能让其他人免去我刚刚忍受的乏味的苦差事。

如果你得到这个,那因为基于 .NET 的 COM 程序集找不到 .NET 框架

解决方案很简单。创建一个包含以下内容的文件

<?xml version="1.0"?>
<configuration>
  <startup>
   <supportedRuntime version="v2.0.50727"/>
  </startup>
</configuration>

将其命名为“Excel.Exe.Config”并将其放在与“EXCEL.EXE”相同的目录中

问题解决了!

于 2008-12-17T20:55:11.993 回答
2

安装以下修复程序将解决此问题 http://www.microsoft.com/downloads/details.aspx?FamilyID=1b0bfb35-c252-43cc-8a2a-6a64d6ac4670&displaylang=en

于 2010-07-08T07:27:48.627 回答
1

RC1,我使用您的 VBScript 代码和 Office 2007 的 Excel 中的代码对此进行了测试,一切正常。

由于您能够从 VB6 表单中创建 COM 对象,我们应该假设您的 .net 框架是可以的。你能排除VBA的问题吗?您可以创建一个 .vbs 文件并将其放入其中吗:

Dim o As Object  
Set o = CreateObject("Test9.COMINT")  
o.Init "A", "B"

保存文件并双击它。如果您收到错误,那么我会认为它的注册存在问题,如果您没有收到错误,那么我会查看 Office 和 VBA 并查看是否缺少某些内容或未正确安装。

另一种选择是添加对 COM 对象的引用并使用早期绑定?我认为您可能需要先导出类型库,但您应该能够添加引用并简单地新建对象。

于 2008-12-17T19:16:48.433 回答
0

这适用于我的 VBA...我使用 Word & Excel 2003 (SP3) 进行了尝试。

我不确定您所说的“生产”机器是什么意思。因为这是一个“客户端”应用程序,必须使用 Excel 在客户端上执行。

如果您在服务器上自动化 Excel 并通过 VBA 调用触发此“互操作”,那么您就是在自找麻烦 :)

假设通过生产,您的意思是用户将使用 Excel 模板/文档的客户端计算机,这些是以下指针:

  1. 确保您拥有适当的 .Net 框架
  2. 你有最新的 Office 服务包
  3. 尝试确定这是否是权利问题。

如果您喜欢冒险,您可以使用进程资源管理器 [来自 Microsoft sysinternals 站点] 查看加载的 DLL 是什么以及您在哪里得到错误,并将其与您的开发框上的列表进行比较。

希望这可以帮助。

于 2008-12-17T18:37:25.610 回答
0

rc1 是正确的,因为这一个 .net 错误,当 Office 无法决定使用哪个版本的框架时抛出。然而,Office 并没有因为选择太多而摇摇欲坠。Office 2003 如何与.net 2.0 交互存在一个错误。

从 Microsoft ( KB908002 ) 安装修复程序是一种比强制 Excel 在特定版本的 .net 中运行更灵活的解决问题的方法。

另见: http: //www.biopdf.com/guide/trouble_shoot_microsoft_office_2003.php

于 2011-08-23T15:27:04.177 回答