SetWindowsHookEx can be used to inject a DLL into another process. A
32-bit DLL cannot be injected into a 64-bit process,and a 64-bit DLL
cannot be injected into a 32-bit process. If an application requires
the use of hooks in other processes,it is required that a 32-bit
application call SetWindowsHookEx to inject a 32-bit DLL into 32-bit
processes,and a 64-bit application call SetWindowsHookEx to inject a
64-bit DLL into 64-bit processes.
我的问题是,如果应用程序是针对任何cpu构建的,会发生什么.我是否需要从针对Any cpu构建的DLL调用SetWindowsHookEx.
我写了HookLogger_32.exe加载HookFunctions_32.dll(包括x86)和HookLogger_64.exe加载HookFunctions_64.dll(都是x64)设置WH_CBT和WH_MOUSE全局(不是特定的线程).
HookLogger_32.exe,HookLogger_64.exe,HookFunctions_32.dll和HookFunctions_64.dll都是用C语言编写的.
当我单击针对Any cpu构建的.NET应用程序时,会注入这些DLL(通过SetWindowHookEx). Windows操作系统挂起&我必须强行重启我的机器.
当针对x86或x64构建相同的.NET应用程序时,当我在HookLoggers(32位和64位)启动后单击应用程序时,一切正常.
这种未定义行为的任何原因.
我工作的平台是64位机器.
在你的情况下有用的东西被称为“并排组装”(同一组件的两个版本,一个32和另一个64位)……我想你会发现这些有用:
> Using Side-by-Side assemblies to load the x64 or x32 version of a DLL
> http://blogs.msdn.com/b/gauravseth/archive/2006/03/07/545104.aspx
> http://www.thescarms.com/dotnet/Assembly.aspx
在这里,您可以找到一个很好的演练,其中包含许多有用的信息 – 它描述了.NET DLL wrapping C++/CLI DLL referencing a native DLL
更新:
要使挂钩变得非常简单和稳健,请参阅this well-tested and free library – 其中包括与Anycpu配合使用!