草庐IT

c - 监控低级 Hook [C]

有没有什么方法可以监控Windows环境中的低级键盘Hook。假设我正在制作一个试图找到键盘记录器的程序。 最佳答案 >没有官方API可以查询已安装的键盘钩子(Hook)。是的,有。(你还太小,不知道这个……)您必须阅读PEB。参见Win32apiGroup所有Windows源代码(每个api,未记录或未记录)都已被反汇编 关于c-监控低级Hook[C],我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com

c++ - 智能感知 : identifier "[blank]" is undefined for each of the variables used in my function

我正在使用VisualStudio。当我尝试编译我的代码时,对于“hexISOS”函数中使用的每个变量,我收到一条错误消息,提示21“IntelliSense:标识符“[blank]”未定义”。我稍后在代码中定义了这些变量,想知道是否有人可以告诉我哪里出了问题。我的代码是这样的:#include#includeusingnamespacestd;inthexISOS(doubleAX,AY,BX,BY,CX,CY,DX,DY){longdoublesol1,sol2;boolans;sol1=sqrt(pow((AX-CX),2)+pow((AY-CY),2));sol2=sqrt(p

c++ - winapi - Hook 应用程序的任务栏选项卡事件

当用户左键/右键单击应用程序的tackbar选项卡时,我无法挂接发送的事件消息。我已经尝试实现OnNcLButtonDown等,但是当我点击应用程序的选项卡时,没有触发任何事件。是否有可能的COM解决方案? 最佳答案 有一条未记录的Windows消息:代码0x0313,当用户右键单击应用程序的任务栏按钮时发送。不知道它是否稳定Hook。 关于c++-winapi-Hook应用程序的任务栏选项卡事件,我们在StackOverflow上找到一个类似的问题: htt

windows - 用于保护驱动程序的注册表访问 Hook

我正在为WindowsNT编写驱动程序,为用户空间应用程序提供Ring-0访问。我想制作一个具有专有权的实用程序来执行任何用户的命令,这些命令将受到保护免受任何外部有害影响。上网发现需要hook一些native内核函数,比如NtOpenProcess、NtTerminateProcess、NtDublicateObject等,我已经制作了一个保护应用程序的工作驱动程序,但后来我意识到最好也防止它从外部尝试删除驱动程序或在操作系统启动期间禁止其加载,如防火墙。我将任务分为两部分:防止从\system32\drivers\中物理删除驱动程序,并防止更改/删除负责加载驱动程序的注册表项(HK

windows - SSDT 注册表 Hook

我是内核编程和驱动程序概念方面的新开发人员。我需要Hookssdt以保护注册表的某些键值,但我找不到任何有用的教程或简单的源代码来处理这些东西。我发现zwopenkey和zwcreatkey应该被Hook,并且它们的权限更改为只读。我正在寻找SSDT注册表Hook的一些示例。 最佳答案 你不需要HookSSDT,你不应该这样做。还有其他方法可以保护您的key。例如,许多解决方案之一是使用registrycallbacks. 关于windows-SSDT注册表Hook,我们在StackOv

ruby-on-rails - rails : How can I access my database on my host machine (windows) from a virtualbox guest (ubuntu)?

我正在尝试设置我的Rails项目(guest:ubuntu),以便它可以访问我的主机操作系统窗口上的sqlserver数据库。我正在使用虚拟框,但是我不确定我的“主机”应该在我的database.yml文件中设置什么。如何找出要将其设置为哪个IP地址和端口?当我在我的Windows操作系统上有这个项目时,我能够将它配置为host:localhost 最佳答案 我必须找到列出的默认网关。所以我在Ubuntu上打开终端并使用以下命令:netstat-rn。这给出了以下结果......KernelIProutingtableDestina

c++ - 从 32 位应用程序 Hook 64 位进程

我正在使用SetWindowHookEx将DLL加载到另一个进程中,但我需要能够挂接到32位和64位进程。我想我需要两个单独的DLL,但是我可以在不创建两个版本的“启动器”应用程序的情况下做到这一点吗?我需要将DLL句柄传递给SetWindowsHookEx,但我无法使用LoadLibrary获取它。 最佳答案 使用进程外COM+对象承载DLL。您可以使用此方法从32位调用64位代码,这样大多数启动器代码都保持不变,除了您决定加载32位或64位COM+对象的if语句。可以对该对象进行编码以将适当版本的DLL加载到进程中,一个用于64

windows - 如何在 Windows git hooks 中使用 cygwin 路径?

(一)我的.git/hooks/pre-commit是#!c:/cygwin/bin/bash.exe#/cygdrive/c/tmp/a.sh当我运行'gitcommit'时出现错误.git/hooks/pre-commit:line8:/cygdrive/c/tmp/a.sh:Nosuchfileordirectory(B)如果.git/hooks/pre-commit是#!c:/cygwin/bin/bash.exe#c:/cygwin/bin/bash.exe/cygdrive/c/tmp/a.sh错误变为/usr/bin/bash:C:/ProgramFiles(x86)/G

c# - 我需要 Hook 什么功能(使用简易 Hook )以防止最小化第三方应用程序?

我正在尝试编写一个简单的东西来防止第三方应用程序能够最小化。我要使用EasyHook因为我认为这是最简单的方法。我的代码将使用C#。我一直在查看EasyHook存储库中的示例,我只是不确定我需要替换哪个Windows函数才能实现此目的。或者,如果有另一种方法也可以做到这一点。示例(不工作):Program.csusingSystem;usingSystem.Text.RegularExpressions;usingEasyHook;namespaceAutoMaximize{internalclassProgram{privatestaticvoidMain(string[]args)

windows - 为什么 SetWindowsHookEx() 返回 NULL 而 LastError 是 ERROR_HOOK_NOT_INSTALLED

我的代码几年来一直没有报告任何问题。它设置了一个低级键盘钩子(Hook),用户可以使用它来激活应用程序。m_hKeyboardHook=SetWindowsHookEx(WH_KEYBOARD_LL,KeybHookFn,GetModuleHandle(NULL),0);突然有一位用户(这在他之前也适用多年),键盘Hook无法正常工作。经过调查,我可以看到SetWindowsHookEx()正在返回NULL,而GetLastError()正在返回0x00000597,即ERROR_HOOK_NOT_INSTALLED。我找不到关于这意味着什么的任何文档。为什么会发生这种情况的可能性有哪