我从64位系统上的32位非托管DLL调用函数。我得到的是:

BadImageFormatException:试图加载格式不正确的程序。(异常来自HRESULT: 0x8007000B)

首先,我把我的项目设置为任何CPU平台,所以我把它们都改为x86,但这个错误仍然发生。这是我知道的唯一解决办法。

dll没有损坏,因为我可以将它们与其他程序一起使用(我没有源代码)。我想也许它没有找到一个依赖,但我检查了一下,它们都在那里。另外,它不会在这种情况下抛出DllNotFoundException吗?

我还能做什么?在您说“改用64位非托管DLL”之前,请允许我指出没有一个DLL。;)


当前回答

如果您在单击绿色箭头按钮运行应用程序时遇到此错误,但仍然希望以64位运行应用程序。你可以在VS 2013、2015、2017和2019中这样做

转到:工具>选项>项目和解决方案> Web项目>使用64位版本的IIS Express

或者你可以在项目属性> Web > Bitness中做每个项目

其他回答

我们在。net核心中也遇到了同样的问题。解决方案是下载32位的。netcore运行时,让你的项目目标是x86

在csproj文件中添加

  <PropertyGroup>
    <PlatformTarget>x86</PlatformTarget>  
  </PropertyGroup>

  <PropertyGroup>
    <RunCommand Condition="'$(PlatformTarget)' == 'x86'">$(MSBuildProgramFiles32)\dotnet\dotnet</RunCommand>    
  </PropertyGroup>

这是用于Windows机器,你必须调整路径,如Linux/OSX

这篇文章有点偏离主题,但是搜索这个错误消息把我带到了这里。

如果您正在通过团队系统进行构建并得到此错误,则构建定义流程选项卡具有“MSBuild Platform”设置。如果设置为“自动”,您可能会遇到此问题。将其更改为“X86”也可以解决该错误。

我用Windows的方式解决了这个问题。在检查所有设置、清理解决方案并重新构建之后,我简单地关闭解决方案并重新打开它。然后它工作了,所以VS可能没有在清洁过程中处理掉一些东西。 当合乎逻辑的解决方案不起作用时,我通常会求助于不合逻辑(或看似不合逻辑)的解决方案。Windows没有让我失望。:)

在我的例子中,我没有将正确的项目设置为启动项目。我进入解决方案设置,选择了正确的启动项目,它工作了

还请注意使用的dll文件(在我的情况下是“WebView2Loader.dll”)的版本是非常重要的。我遇到了几乎相同的问题“Microsoft.WebView2.FixedVersionRuntime.101.0.1210.39。当我试图使用MMC管理单元中的WebView2组件与“HTMLView”或“FormView”类型时。

我只是将引用的dll文件复制到项目可访问的适当路径(您可以先将其放在项目输出文件旁边进行测试),然后WebView2浏览器开始按预期运行。微软的错误消息有时(至少在我的情况下)有点误导,没有传达足够的信息。

我收到了“BadImageFormatException”,通常发生在你混合平台目标(例如,在一个针对x86的应用程序中使用X64编译的dll文件,反之亦然)或混合本机代码和. net时,但这根本不是我的问题。我希望这能帮助那些可能陷入困境的人。