草庐IT

CRT_DEBUGGER_HOOK

全部标签

c++ - Easyhook:非托管 Hook ,如何调用原始函数/更改返回状态?

所以我在winspool.drv!WritePrinter上有一个Hook函数,它成功地Hook了远程注入(inject)到spoolsv.exe的非托管C++。目前,Hook似乎要么替换原始函数,要么以无法检测的方式破坏堆栈:Hook后,WritePrinter调用导致Hook外没有打印机事件。我发现至少有一种方法可以调用原始函数,即所谓的LhGetOldProc。但是,使用它会导致崩溃,不确定这是与easyhook相关的错误还是只是错误的转换。那么,如何在Easyhook非托管版本中正确调用原始函数?使用LhGetOldProcHook回调:UCHAR*uc=NULL;LhGetO

c++ - 全局 Hook 是否可以跨 x86 和 x64 工作

我试图将所有内容嵌入到一个COMdll中。目前我按如下方式连接了WH_GETMESSAGE和WH_CBT:BOOLTouchDetector::SetMessageHook(BOOLInstall){if(Install){return((mHookMessage=::SetWindowsHookEx(WH_GETMESSAGE,MessageHookProc,mDll,0))!=NULL)&&((mHookWin=::SetWindowsHookEx(WH_CBT,WinHookProc,mDll,0))!=NULL);}else{returnUnhookWindowsHookEx(

c++ - 使用 C++ 和 EasyHook 注入(inject) x64 进程 Hook x86-DLL 的 x64-DLL 失败

注入(inject)x64进程的x64-DLL使用C++和EasyHookHookx86-DLL失败。如果Loader、InjectionLibrary和InjectionTarget(它在两个版本中都可用,我需要两者都被Hook)是x86,它就可以工作。获取导出过程的地址(GetProcAddress本身)在x64上不是问题。InjectionTarget也有HookTarget(Kernel32.dll)作为x64的依赖项。LhInstallHook(...)返回STATUS_NOT_SUPPORTED,其中源评论说在以下情况下发生:“目标入口点包含不受支持的指令。”由于源适用于x

c++ - Qt 5.4 中的 "No debugger set up"

这个问题在这里已经有了答案:QtCreator5-Nodebuggersetup(1个回答)关闭7年前。我已经安装了QtCreator(Qt5.4)。当我调试我的Qt项目时,它不会显示“未设置调试器”。现在我的电脑上已经安装了VC-2010,显然我有调试器(我验证了所有的工作)但是我是否必须为QtCreator下载另一个调试器?如何配置调试器才能工作?

c++ - 鼠标 Hook - 限制和性能

我有一些关于WH_MOUSE的问题。根据我的阅读,通过将钩子(Hook)放入DLL中,它会注入(inject)进程。这是否意味着捕获鼠标也适用于我的桌面、菜单启动等?那么应用程序的标题栏呢?我在Internet上看到过一些有此类问题的帖子,但不知道他们是否因某些原因失败或存在某种限制(或其他方法)。我还有一个关于WH_MOUSE和WH_MOUSE_LL之间性能的问题。我在某处发现WM_MOUSE比WH_MOUSE_LL快,但它真的很明显吗?如果是这样,在什么情况下它会使系统减慢我们可以注意到的程度?如果我只想记录鼠标和键盘的点击,WH_MOUSE_LL是否有效?谢谢!

c++ - ld : file not found:/usr/lib/crt1. o

在MacOSXSierra上尝试使用PGI编译Fortran时,出现错误ld:filenotfound:/usr/lib/crt1.o我找到了适用于旧版MacOSX的解决方法(http://www.pgroup.com/userforum/viewtopic.php?t=4578)sudoln-s/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.10.sdk/usr/lib/crt1.o/usr/lib/crt1.o但是,对于Sierra,系统完整性保

C++ Function Hook(仅内存地址)

我有一个内存地址,它是另一个程序(它的一个dll)中函数的内存地址。我已经通过DLL注入(inject)加载到程序中。我已经有了bass地址,以及每次程序加载时函数的实际位置。所以,这不是问题。我只想Hook那个位置,然后获取变量。我知道函数的伪代码。所以这不是问题。或者另一种很棒的方法是在该内存位置做一个断点并获取调试寄存器。我找不到任何明确的例子。我也没有函数的“名称”,我只有内存地址。有什么方法可以只使用内存地址吗?大多数(如果不是所有的话)示例都让您使用函数的名称,而我没有。如果有人能为我指明正确的方向以便我完成这项任务,我将不胜感激。它也可能会帮助很多其他可能有相同问题的人。

c++ - VS 2012 : Debugger: "Break all in 5 seconds"

当我选择文本时,我的程序使用了过多的CPU资源。我不知道为什么。通常我只是按“全部中断”来查看程序当前正在做什么。但在这种情况下,我正忙于用鼠标选择文本。有什么技巧可以延迟“全部中断”命令几秒钟吗? 最佳答案 您可以使用Sleep(5000)启动一个单独的线程;DebugBreak(); 关于c++-VS2012:Debugger:"Breakallin5seconds",我们在StackOverflow上找到一个类似的问题: https://stackove

c++ - 使用 cmake 添加 _CRT_SECURE_NO_WARNINGS 定义

是否可以使用cmake添加_CRT_SECURE_NO_WARNINGS预处理器定义?add_definitions(-CRT_SECURE_NO_WARNINGS)add_definitions(-_CRT_SECURE_NO_WARNINGS)add_definitions(_CRT_SECURE_NO_WARNINGS)这些是我到目前为止尝试过的。这些尝试都没有成功。 最佳答案 使用这个:if(MSVC)add_definitions(-D_CRT_SECURE_NO_WARNINGS)endif()参见here获取官方文档。

C++ - 绕过 WinSock Hook

我想做的是使用theDetourslibrary连接到应用程序WinSock2send()和recv()函数(数据包记录器)。虽然它确实适用于send()函数,但它不适用于recv()函数。这是我的相关代码:#include#include#include#include#include#include#include#pragmacomment(lib,"Ws2_32.lib")#pragmacomment(lib,"detours.lib")#pragmacomment(lib,"detoured.lib")#pragmacomment(lib,"Mswsock.lib")std: