将工作C#项目从64位Windows 7计算机移动到32位XP计算机会导致以下错误:
使用CLSID检索组件的COM类工厂 {681EF637-F129-4AE9-94BB-618937E3F6B6}由于以下原因而失败 错误:80040154。
681EF637-F129-4AE9-94BB-618937E3F6B6不在注册表中,因此未正确安装,但这是以前在64位Windows 7计算机上出现问题的ID。找到了64位Windows 7计算机上此错误的解决方案here(将平台目标更改为x86),但这并未解决32位XP计算机上的问题。如何找到与681EF637-F129-4AE9-94BB-618937E3F6B6相关的dll,或者更好的是,如何修复此异常?
答案 0 :(得分:22)
要查找DLL,请转到64位计算机并打开注册表。找到名为HKEY_CLASSES_ROOT\CLSID\{681EF637-F129-4AE9-94BB-618937E3F6B6}\InprocServer32
的密钥。此密钥将DLL的文件名作为其默认值。
如果您通过重新编译x86的项目解决了64位计算机上的问题,那么您需要查看注册表的32位部分而不是正常位置。这是HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Classes\CLSID\{681EF637-F129-4AE9-94BB-618937E3F6B6}\InprocServer32
。
如果DLL是为32位构建的,那么您可以直接在32位计算机上使用它。如果它是为64位构建的,那么你必须联系供应商并从中获得32位版本。
当你有DLL时,通过运行c:\ windows \ system32 \ regsvr32.exe来注册它。
答案 1 :(得分:12)
我在Windows服务中遇到了同样的问题。所有密钥位于注册表中的正确位置。服务的构建是为x86完成的,我仍然有例外。我发现了CorFlags.exe
在没有标志的service.exe
上运行此操作以验证您是否在32位下运行。如果没有使用标志/32BIT+ /Force
运行它
(仅对已签名的程序集强制执行)
如果您已启用UAC,则可能会收到以下错误:corflags : error CF001 : Could not open file for writing
授予用户对程序集的完全控制权。
答案 2 :(得分:9)
替代方法:
可能的解决方法是从任何CPU'修改您的项目平台。到' X86' (在项目的属性,构建/平台'目标)
根本原因
VSS Interop是使用32位Framework的托管程序集,dll包含32位COM对象。如果在64位环境中运行此COM dll,则会收到错误消息。
答案 3 :(得分:-2)
将表单中全局声明的excel变量移动到本地,就像我的表单一样:
Dim xls As New MyExcel.Interop.Application
Dim xlb As MyExcel.Interop.Workbook
以上两行在我的表单中声明为全局,所以我将这两行移动到本地函数,现在工具工作正常。