草庐IT

register_activation_hook

全部标签

c++ - GCC- 无效使用 Register

我正在VS2012和GCC(CodeBlocks)下为Windows编译一个项目。在VS2012上一切正常。在GCC下,我得到以下编译错误:C:\Users\Piotrek\AppData\Local\Temp\ccfdl0Ye.s|164|Error:invaliduseofregister|C:\Users\Piotrek\AppData\Local\Temp\ccfdl0Ye.s|166|Error:invaliduseofregister|C:\Users\Piotrek\AppData\Local\Temp\ccfdl0Ye.s|221|Error:invaliduseofr

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

如何使用ADAL从Azure Active Directory获取用户角色

我正在研究使用的Android应用程序阿达尔库对用户进行身份验证,现在需要根据其AD角色为特定的一组用户显示某些操作。如何访问广告用户角色?Android应用与ASP.NETWebAPI服务进行交互看答案如果您的角色是指小组成员资格,则至少有两种方式:将groupMembershipclaims设置为“SecurityGroup”或您应用中的“ALL”AAD中的“ALL”这使您可以在ID令牌中收到用户的组成员资格(这为您提供了用户的名称等)返回的只是组的ID,而不是名称返回的最大200组ID的限制您可以找到一些信息这里,尽管它适用于旧门户(在新门户中更容易清单管理)或者,您可以从Microso

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++ - 鼠标 Hook - 限制和性能

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

c++ - QtCreator : How do I register "override" and "final" as a keyword?

C++11(或C++0x)向C++引入了override和final关键字。很棒的东西,我们将使用它们来改进我们的代码。但是,虽然MSVisual-C++2010编译器完美地处理了关键字,但QtCreator(我选择的IDE)却完全被它们搞糊涂了。override方法被标记为错误,而且——更糟糕的是——所有代码导航功能或符号代码搜索都被完全搞砸了。:(我的问题就这么多了。我的问题如上:如何教QtCreator将override和final识别为关键字?谢谢!--罗宾PS:我使用QtCreator2.3,AFAIK的最新稳定版本。编译器为MSVC2010。 最

c++ - FREENECT_DEPTH_REGISTERED 对 libfreenect 没有影响

我正在libfreenect驱动程序上玩Kinect(原始Xbox版本)(顺便说一句,我在Ubuntu12.04上)。我已经从git克隆了最新版本并按照此处的说明手动安装:http://openkinect.org/wiki/Getting_Started#Ubuntu_Manual_Install我想访问注册的深度值。据我所知,Kinect是出厂校准的,并且有一个将深度像素与正确的RGB像素匹配的查找表。我可以很好地打开Kinect并检索原始的11位深度数据。对于1到7.5米的距离,这给了我非线性范围从730到1045的值。运行device->setDepthFormat(FREEN

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

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