- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我在 Ctypes 中加载 Windows DLL 时遇到问题,这引发了错误:
WindowsError: [Error 193] %1 is not a valid Win32 application
在我的例子中,它是一个在 Windows 7 64 位上使用 VS2012 构建的 32 位 DLL,在我的开发机器上我可以很好地加载它。我使用 dumpbin/headers
检查它是 32 位的:
FILE HEADER VALUES
14C machine (x86)
当我尝试在生产虚拟机(也是 Windows 7 64 位)上通过 Ctypes 加载相同的 DLL 时出现问题。我正在做的是:
from ctypes import *
self.dll = CDLL(dllabspath)
我得到:
File "C:\Users\user\Desktop\WinPython-32bit-2.7.10.1\.....\__init__.py", line 365, in __init__
self._handle = _dlopen(self._name, mode)
WindowsError: [Error 193] %1 is not a valid Win32 application
在其他问题中,我已经尝试了几件事。
This , this , this和 this问题表明我的环境必须相同,即 32 位 Python、32 位 DLL。我的开发系统和我正在测试的 VM 就是这种情况。在两者上,我都使用 WinPython 32 位最新版本。它在开发机器上工作,在 VM 上失败。
Here ,它与 g++ 相关,并且依赖于旧的 Visual Studio 运行时。我用 VS2012 编译了所有东西,所以我认为这在这里不适用。存在对需要 MSVCR80.dll
的第三方库的延迟加载依赖项,但它已延迟加载且从未被调用。
我还在目标机器上安装了 Visual C++ 32 位运行时。
This建议 DLL 需要导出 C 接口(interface),它确实这样做了。
我知道 DLL 的文件路径/文件名是正确的,和以前一样,存在缺少 DLL 依赖项的问题,我得到了一个 Windows 弹出窗口。这些现在都没有了。
该错误非常笼统,相当神秘。由于它在同一个 Python 环境中的开发机器上工作,我假设它与一些只有 Visual Studio 安装才能给我的依赖关系有关?
如何正确解决此问题?
最佳答案
@eryksun 评论道:
Run under a debugger such as
cdb
orwindbg
. Callwindll.kernel32.DebugBreak()
just before callingCDLL(dllabspath)
. Set a breakpoint onkernelbase!LoadLibraryExW
and resume the thread viag
. When it breaks back into the debugger enterpt
to execute up to the function return. Then enter!teb
to check theLastStatusValue
for the thread. This NT status value may be of more help.
进一步:
If you prefer to keep the system as clean as possible, try the following:
windll.kernelbase.LoadLibraryExW(c_wchar_p(dllabspath), None, 0); status = windll.ntdll.RtlGetLastNtStatus().
Otherwise it requires installing the debugging tools from the SDK. Symbols can be downloaded on demand from Microsoft's symbol server by setting the environment variable
_NT_SYMBOL_PATH=symsrv*symsrv.dll*C:\Symbols*http://msdl.microsoft.com/download/symbols
, which caches symbols inC:\Symbols
调试时,这可能会有所帮助:
There are several status codes that produce Win32 error
ERROR_BAD_EXE_FORMAT
(193). In your case it'sSTATUS_INVALID_IMAGE_FORMAT
(0xC000007B
). Possibly in the production VM one of the dependent DLLs that it tries to load is 64-bit. At the breakpoint enterdu poi(@esp+4)
to print the first argument, which is the unicode path of the DLL it's attempting to load. Also check the stack trace viakc
.
使用这个提示,我发现了对 64 位 WinPCAP DLL 的依赖。使用 DependencyWalker 检查所有内容,它在两台机器上看起来都一样,提示 64 位依赖性,但显然在新机器上,DLL 加载路径不同并且它永远找不到 32 位版本。
关于python - Ctypes 抛出 "WindowsError: [Error 193] %1 is not a valid Win32 application",但这不是 32/64 位问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31804110/
我是一名优秀的程序员,十分优秀!