BadImageFormatException 无法加载文件或程序集或其依赖项之一。试图加载格式不正确的程序

Posted

技术标签:

【中文标题】BadImageFormatException 无法加载文件或程序集或其依赖项之一。试图加载格式不正确的程序【英文标题】:BadImageFormatException Could not load file or assembly or one of its dependencies. An attempt was made to load a program with an incorrect format 【发布时间】:2017-09-22 11:03:38 【问题描述】:

我的控制台应用程序 (VS2012) 引用“dcasdk.dll”时出现以下运行时错误。 控制台应用的 .Net Framework 为 4.5,平台目标为“Any CPU”。

Could not load file or assembly 'dcasdk, Version=1.0.1.0, Culture=neutral, PublicKeyToken=null' or one of its dependencies. An attempt was made to load a program with an incorrect format.

我使用 CorFlags 应用程序来检查 dll 的目标平台。下面是详细内容。。

Version : v4.0.30319
CLR Header : 2.5
PE : PE32
CorFlags : 16
ILONLY : 0
32BIT : 0
Signed : 0

根据上面的信息,我认为 dll 也是使用“任何 CPU”目标构建的。因此它应该与具有相同目标平台的控制台应用程序一起使用。我不知道为什么我在运行时会收到此错误。

我还尝试将目标平台更改为 x86,这会给出以下“FileNotFoundException”。我在反射器中检查了 dll 的引用。它只显示 System.Xml 和 System.Data。已在控制台应用中作为参考添加。

Could not load file or assembly 'dcasdk.dll' or one of its dependencies. The specified module could not be found.

对此的任何帮助将不胜感激。

提前致谢。

下面是 Fusion 的组装绑定日志。根据最后三行错误信息,这似乎是组装平台的问题。但由于这是第三方 dll,我无法将其重新编译到任何特定平台。请分享您对这里可以做什么的想法..

请注意,我在 Windows7 64 位操作系统上运行此控制台应用程序。

*** Assembly Binder Log Entry  (4/26/2017 @ 8:31:08 AM) ***

The operation failed.
Bind result: hr = 0x8007000b. An attempt was made to load a program with an incorrect format.

Assembly manager loaded from:  C:\Windows\Microsoft.NET\Framework64\v4.0.30319\clr.dll
Running under executable  C:\ConsoleApplication3\ConsoleApplication3\bin\Debug\ConsoleApplication3.vshost.exe
--- A detailed error log follows. 

=== Pre-bind state information ===
LOG: DisplayName = dcasdk, Version=1.0.1.0, Culture=neutral, PublicKeyToken=null
 (Fully-specified)
LOG: Appbase = file:///C:/ConsoleApplication3/ConsoleApplication3/bin/Debug/
LOG: Initial PrivatePath = NULL
LOG: Dynamic Base = NULL
LOG: Cache Base = NULL
LOG: AppName = ConsoleApplication3.vshost.exe
Calling assembly : ConsoleApplication3, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null.
===
LOG: This bind starts in default load context.
LOG: Using application configuration file: C:\ConsoleApplication3\ConsoleApplication3\bin\Debug\ConsoleApplication3.vshost.exe.Config
LOG: Using host configuration file: 
LOG: Using machine configuration file from C:\Windows\Microsoft.NET\Framework64\v4.0.30319\config\machine.config.
LOG: Policy not being applied to reference at this time (private, custom, partial, or location-based assembly bind).
LOG: Attempting download of new URL file:///C:/ConsoleApplication3/ConsoleApplication3/bin/Debug/dcasdk.DLL.
LOG: Assembly download was successful. Attempting setup of file: C:\ConsoleApplication3\ConsoleApplication3\bin\Debug\dcasdk.dll
LOG: Entering run-from-source setup phase.
LOG: Assembly Name is: dcasdk, Version=1.0.1.0, Culture=neutral, PublicKeyToken=null
ERR: Invalid assembly platform or ContentType in file (hr = 0x8007000b).
ERR: Run-from-source setup phase failed with hr = 0x8007000b.
ERR: Failed to complete setup of assembly (hr = 0x8007000b). Probing terminated.

如果我将“首选 32 位”设置为 ON,那么上述错误就会消失。但是我仍然收到“FileNotFoundException”、“无法加载文件或程序集 'dcasdk.dll' 或其依赖项之一。找不到指定的模块。”。但是这次 Fusion 日志中没有错误!

*** Assembly Binder Log Entry  (4/26/2017 @ 9:57:53 AM) ***

The operation was successful.
Bind result: hr = 0x0. The operation completed successfully.

Assembly manager loaded from:  C:\Windows\Microsoft.NET\Framework\v4.0.30319\clr.dll
Running under executable  C:\ConsoleApplication3\ConsoleApplication3\bin\Debug\ConsoleApplication3.vshost.exe
--- A detailed error log follows. 

=== Pre-bind state information ===
LOG: DisplayName = dcasdk, Version=1.0.1.0, Culture=neutral, PublicKeyToken=null
 (Fully-specified)
LOG: Appbase = file:///C:/ConsoleApplication3/ConsoleApplication3/bin/Debug/
LOG: Initial PrivatePath = NULL
LOG: Dynamic Base = NULL
LOG: Cache Base = NULL
LOG: AppName = ConsoleApplication3.vshost.exe
Calling assembly : ConsoleApplication3, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null.
===
LOG: This bind starts in default load context.
LOG: Using application configuration file: C:\ConsoleApplication3\ConsoleApplication3\bin\Debug\ConsoleApplication3.vshost.exe.Config
LOG: Using host configuration file: 
LOG: Using machine configuration file from C:\Windows\Microsoft.NET\Framework\v4.0.30319\config\machine.config.
LOG: Policy not being applied to reference at this time (private, custom, partial, or location-based assembly bind).
LOG: Attempting download of new URL file:///C:/ConsoleApplication3/ConsoleApplication3/bin/Debug/dcasdk.DLL.
LOG: Assembly download was successful. Attempting setup of file: C:\ConsoleApplication3\ConsoleApplication3\bin\Debug\dcasdk.dll
LOG: Entering run-from-source setup phase.
LOG: Assembly Name is: dcasdk, Version=1.0.1.0, Culture=neutral, PublicKeyToken=null
LOG: Binding succeeds. Returns assembly from C:\ConsoleApplication3\ConsoleApplication3\bin\Debug\dcasdk.dll.
LOG: Assembly is loaded in default load context.

“FileNotFoundException”堆栈跟踪..

mscorlib.dll!System.AppDomain.ExecuteAssembly(string assemblyFile, System.Security.Policy.Evidence assemblySecurity, string[] args)
Microsoft.VisualStudio.HostingProcess.Utilities.dll!Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly()
mscorlib.dll!System.Threading.ThreadHelper.ThreadStart_Context(object state)
mscorlib.dll!System.Threading.ExecutionContext.RunInternal(System.Threading.ExecutionContext executionContext, System.Threading.ContextCallback callback, object state, bool preserveSyncCtx)
mscorlib.dll!System.Threading.ExecutionContext.Run(System.Threading.ExecutionContext executionContext, System.Threading.ContextCallback callback, object state, bool preserveSyncCtx)
mscorlib.dll!System.Threading.ExecutionContext.Run(System.Threading.ExecutionContext executionContext, System.Threading.ContextCallback callback, object state)
mscorlib.dll!System.Threading.ThreadHelper.ThreadStart()

问题和修复:

原来是找不到 dcasdk dll 的依赖项的问题。我确实联系了第三方提供商,他们确认 dcasdk dll 依赖于另外两个 dll(由他们稍后提供),添加后解决了问题!

感谢大家帮助我理解这个问题。


当我尝试将其部署为在 Windows 服务器 R2 上运行的机器中的 Windows 服务时,我再次收到 FileNotFoundException。

我尝试使用“Prefer 32”进行编译,结果出现“BadImageFormatException”。

如果我使用 x86 平台目标进行编译,我会收到 FileNotFoundException,尽管所有需要的 dll 都存在于服务文件夹中。

谁能帮助我了解部署出了什么问题。它可以在开发系统中按预期使用“任何 CPU,首选 32 位开启”。

【问题讨论】:

一行回答——x64和x86版本问题。 DLL 是从哪里来的呢?如果您仅通过更改位数获得FileNotFoundException,这似乎表明该文件未从您认为的位置复制到您认为的位置。事实是 DLL 已损坏,或者它的位数与进程的位数不匹配,无论 corflags 告诉您什么。如有必要,打开程序集绑定日志记录以仔细检查“dacsdk”的加载位置。 感谢@JeroenMostert 给它一个正确的方向,你能看看我上面更新的问题吗?知道错误“无效的程序集平台或文件中的 ContentType”表示什么吗?为什么即使我将“目标平台”更改为 x86\x64.. 也不起作用?请分享你的想法。再次感谢您的时间。 替换您的程序集版本并替换程序集名称,如(System.Web.Helpers) @Vishal,这很有效...再次出现相同的“FileNotFoundException”错误.. 【参考方案1】:

如前所述,这也是由于错误的架构造成的 a) 在 Windows x86 中使用 x64 程序集 b) 将 x86 程序集与 x64 进程一起使用,反之亦然

为获得最佳效果,请确保所有 .NET 程序集均使用“任何 CPU”和相同的 .NET 配置文件(即全部使用 .NET Core、客户端配置文件或完整的 .NET)构建。

...或者根本没有找到一个依赖项,启用 Fusion Log 以告知要在哪里收集程序集:

见How to enable assembly bind failure logging (Fusion) in .NET 和 http://www.hanselman.com/blog/BackToBasicsUsingFusionLogViewerToDebugObscureLoaderErrors.aspx

更新:鉴于错误代码 0x8007000b,我很确定是架构不匹配: a) dll 可能是完整的 .NET 代码,但未使用 AnyCPU 编译 b) dll 可能是本机代码,然后您需要一个匹配的架构(加上一些使用 PInvoke 调用它的代码) c) dll 可能是 C++ CLI(本机/.NET 代码的混合,同样具有错误的架构)。 d) dll 可能已损坏。

您可能需要联系第 3 方提供商以获得支持。 此外,此链接提到它可能与 .NET 版本不匹配。

无论如何,看起来问题已经缩小了。

另外,如果 DLL 是部分原生的,它可能需要 MSVC 运行时(正如这个问题的答案所提到的,Using 32-bit dll on 64-bit system shows 0x8007000B Error)

在这种情况下,问题将是找不到 dcasdk 的依赖项。 您可以检查哪个 Dependency Walker,请参阅 http://www.dependencywalker.com/ (它还有一个配置文件模式,您可以在其中配置一个 exe,并查看打开运行时失败的 dll 的调用)。

【讨论】:

非常感谢您提供有关“Fusion”的信息。我已经用“Assembly Binding Logs”更新了我上面的问题。你能看看吗?由于这是第三方 dll,我无法重新编译它。有没有其他方式来看待这个问题? 您好,提供了更多详细信息。 我正要投票,但后来我在 1337 看到了你的代表。享受这一刻! 你是对的!...我确实联系了第三方提供商,他们确认 dcasdk dll 与另外两个 dll 有依赖关系,添加后解决了问题。我会尝试使用dependency walker,因为在这种情况下它似乎真的很有用。非常感谢您的时间和帮助! 我不敢相信我没有看建筑类型。愚蠢的错误,但这个答案让我直截了当。【参考方案2】:

在 VS 中,转到 tools,然后点击 options

在搜索栏中搜索“iis”并选中此选项,然后运行项目,这对我有用,因为我在 Web 项目中遇到错误。

【讨论】:

【参考方案3】:

右键单击项目设置,然后单击构建并根据您的 dll 设置将平台目标从 Any 设置为 x64 或 x86 。

对我来说,我试图通过 AnyCpu 设置加载 x64 dll。我将 AnyCpu 设置更改为 x64,它开始为我工作。

【讨论】:

以上是关于BadImageFormatException 无法加载文件或程序集或其依赖项之一。试图加载格式不正确的程序的主要内容,如果未能解决你的问题,请参考以下文章

WCF 服务 BadImageFormatException

BadImageFormatException 未处理

System.BadImageFormatException:如何修复 .NET 版本不匹配?

System.BadImageFormatException

.NET 程序集中 BadImageFormatException 的替代原因?

System.BadImageFormatException:无法加载文件或程序集(来自 installutil.exe)