草庐IT

c++ - 如何使用非托管 EasyHook 从进程中的任何线程 Hook 方法?

我在使方法Hook正常工作时遇到了一些问题。如果“我”调用被Hook的方法,我就可以让Hook工作。但是当它在进程运行期间自然发生时,它不会被钩住。我的问题可能源于这样一个事实,即我实际上是在我自己生成的线程中设置这些Hook。显然LhSetInclusiveACL()方法需要知道您要Hook的线程。好吧,这是我的问题...我真的不在乎哪些线程应用了钩子(Hook),我希望它们都被钩住。例如,假设我希望“gdi32.dll”库中的CreateICW()方法与整个进程“iexplorer.exe”Hook。不仅仅是来自线程ID号48291或其他。了解哪些线程将调用您感兴趣的Hook例程需

C++ Hook 我自己的程序函数

所以我想分析我的应用程序,我特别想记录从程序开始到程序内部调用的每个函数(忽略DLL中的函数)进入和退出的时间,即我想要一个简单的表看起来像这样:THREAD_IDFUNCTION_ADDRESSTIMEEVENT_TYPE55200xFF4353600ENTERED55200xFF435ED325ENTERED55200xFF43355040ENTERED55200xFF43355050EXITED55200xFF43355060ENTERED55200xFF43355070EXITED55200xFF435ED382EXITED55200xFF43536090EXITED对于这样一

c++ - Boost.intrusive 多容器

在boost.intrusive文档中,提到了使用多个容器存储在一个对象中。但是,没有实际的例子,所以我自己做了。这是正确的做法吗?#includestructtag1;classA:publiclist_member_hook,publiclist_member_hook>{}typedeflist_base_hook>TagHook;typedeflistDefaultList;typedeflist>TagList;intmain(){DefaultListdList;TagListtList;A*a=newA();dList.push_back(a);tList.push_ba

git hook 自动设置作者

问题背景在日常版本控制操作中,时常会遇到因混淆不同场景下的身份信息而导致的邮件地址误用问题,例如,在提交企业内部项目时意外使用了个人邮箱地址,或是在向GitHub等公共平台提交代码时采用了公司专属邮箱。为解决此类问题,期望实现一种自动化机制,使得Git在执行提交操作时能根据目标远程仓库的域名智能切换相应的邮箱配置,确保与项目及环境相匹配的身份标识得以正确运用。实现方案认识GitHooksGitHook是Git仓库中的一组脚本,它们允许你在特定的Git事件发生时执行自定义操作。这些脚本放置在.git/hooks目录下,并且每个脚本对应一个特定的Git生命周期事件。以下是一些常见的GitHook类

c++ - SetWindowsHookEx - Dll 注入(inject)错过了前几次调用

我正在尝试使用SetWindowsHookEx来捕获对java.dll中API的调用。所以我创建了另一个dll,并使用setwindowsHookEx注入(inject)到所有其他进程中g_hHook=SetWindowsHookEx(WH_CALLWNDPROC,JLoadSetFunc,g_hHookDll,0)问题如下:在trycatch来自某个进程的调用时,我注意到我的dll在已经执行了几次对Hook函数的调用后附加到该进程。所以问题是我的Hook机制错过了HookAPI的前几次调用。请建议或评论此问题以指导我。我被这个卡住了。 最佳答案

c++ - 使用 Assembly 和 C++ 调用一个函数两次

我有一个代码可以将要调用的函数更改为我的新函数,但我不想只调用我的新函数,我还想调用旧函数。这是一个示例,因此您可以理解我在说什么:如果我反汇编我的.exe,我会看这部分:L00123456:moveax,[L00654321]//doesn'tmattermovecx,[eax+1Ch]//doesn'tmatterpushesi//theonlyparameter0x123callSUB_L00999999//thisisthefunctionIwannaoverwrite//...(0x123是那一行的地址)所以,我使用了这段代码:DWORDold;DWORDfrom=0x123

c++ - wxWidgets 的 EVT_CHAR_HOOK 有什么作用?

我正在维护一个wxWidgetsC++应用程序,它使用EVT_CHAR_HOOK来捕获高级窗口中的关键事件。我找不到关于此事件的任何真实文档,但我可以推测它以某种优先于“标准”键事件的方式拦截键事件。我刚刚发现的一件令人不安的事情是,如果此Hook就位,则可能已定义的任何快捷键将不再触发它们的事件,即使事件处理程序在事件上调用Skip()也是如此。我在谷歌上搜索时也看到一些帖子似乎暗示EVT_CHAR_HOOK可能并非在所有平台上都受支持。这是真的吗?我应该使用它吗? 最佳答案 我刚刚查看了src/gtk/window.cpp并找到

c++ - 使用 C++ Hook GetTickCount

我不太擅长C++,更擅长C#和PHP。我被分配了一个项目,要求我使用GetTickCount并挂接到应用程序。我需要一些帮助,因为某些原因它没有按计划工作......这是Hook的代码,我知道它有效,因为我以前在项目中使用过它。我唯一不太确定的是它的GetTickCount部分。我尝试了GetTickCount64,认为这是解决我的问题的方法(它并没有使我注入(inject)的内容崩溃),但发现它根本不起作用,所以它没有崩溃boolAPIENTRYDllMain(HINSTANCEhDll,DWORDdwReason,LPVOIDlpReserved){switch(dwReason)

c++ - Firefox pr_write 钩子(Hook)。 dll 注入(inject),Windows 钩子(Hook)

问题是包含PR_Write()的DLL调用的不是npsr4.dll,而是nss3.dll和Hook无法从不存在的库中找到GetProcAddress()。我正在尝试创建FirefoxHook,它从PR_Write()Firefox方法(它位于nspr4.dll中)收集数据。我在谷歌上搜索了很多,并尝试了很多方法来做到这一点,但不幸的是,当我注入(inject)钩子(Hook)时,Firefox崩溃了。首先,我尝试不使用DLL,使用这个方法http://redkiing.wordpress.com/2012/04/30/firefox-formgrabber-iii-code-injec

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

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