草庐IT

EVT_CHAR_HOOK

全部标签

C++ 中间函数 Hook : get register values and jump back [x86 assembly on windows]

在寄存器EBP中有一个int值,在EBX中有一个字符串。我需要在我自己的函数中从这些寄存器中获取值,对它们进行一些操作,最后跳回下面的一些代码。我在0x46AA17处对名为JmpHook的函数执行了一个JMP。voidJmpHook(){char*mystring;_asmmovmystring,ebxprintf("value:%s",mystring);_asm{jmp[0x46AA87]}}如您所见,我正在尝试将EBX处的字符串移动到mystring中,最后跳回0x46AA87,这是位于我的JMPJmpHook下方的几行。printf被调用并且mystring被输出,但所有这些在

c# - VSTO Windows Hook keydown 事件调用 10 次

因此,我一直在开发一个类来处理VSTO加载项中的Kwyboard输入,到目前为止,我一直在使用WindowsHook来完成此操作并取得了相对成功。有这段代码://.....privateconstintWH_KEYBOARD=2;privateconstintWH_MOUSE=7;privateenumWM:uint{KEYDOWN=0x0100,KEYFIRST=0x0100,KEYLAST=0x0108,KEYUP=0x0101,MOUSELEFTDBLCLICK=0x0203,MOUSELEFTBTNDOWN=0x0201,MOUSELEFTBTNUP=0x0202,MOUSEM

windows - 预提交 Hook 以检查 Jira 问题 key

我正在寻找帮助在Windows上编写预提交Hook以在提交时检查Jira问题key。如果Jirakey不存在,则不应允许提交。我找不到任何方法。我是脚本编写的新手。任何帮助将不胜感激。 最佳答案 我假设您正在谈论Git存储库中的Hook。导航到您的本地Git存储库并进入文件夹.git\hooks创建一个名为commit-msg的文件插入以下内容(不知道如何正确格式化)#!/bin/bash#Thescriptbelowaddsthebranchnameautomaticallyto#everyoneofyourcommitmessa

Windows 键盘 Hook 挂起调试器

我有一个从主应用程序中的辅助(非GUI)线程启动的插件DLL。DLL必须从应用程序的主窗口中获取键盘事件。我正在使用SetWindowsHookEx(),效果很好。但是,如果我在Hook处于事件状态时在VisualStudio中遇到断点,然后按下一个键,VisualStudio和我的应用程序将完全锁定。这是一个问题,因为我通常使用F键逐步执行代码。如果我使用鼠标并从VisualStudio的“调试”菜单向前迈进,它工作正常。但是使用F10等。就是这样的习惯,我经常忘记用鼠标。我能做些什么来恢复我的键盘快捷键吗?或者用不同的方法来听键盘? 最佳答案

windows - 检测/ Hook 其他外部进程的窗口移动/拖动

检测其他进程的窗口移动/拖动的最佳方法是什么?在Windows764位中我目前正在研究使用C++和C#的DLL中的全局Hook。这很痛苦,因为它不想正常工作。我在键盘和鼠标Hook方面取得了一些成功。但对于窗口消息,我只是不知道出了什么问题。这是我的.dll文件中的代码#include#include#includeHINSTANCEhinst;#pragmadata_seg(".shared")HHOOKhhk;WNDPROCrealProc;#pragmadata_seg()//#pragmacomment(linker,"/SECTION:.shared,RWS")compile

c++ - 从 WM_CHAR 消息中获取扫描码

如何将通过WndProc中的WM_CHAR捕获的任何语言的字符转换为键盘扫描码?就像按下的按钮是x它会返回0x2d等等。 最佳答案 根据WM_CHAR,扫描码在lParam参数的第16-23位中文档,所以只需移位和掩码:intscanCode=(lParam>>16)&0xff;如果你有一个角色,你可以调用OemKeyScan,将扫描码放在低字节:charc='X';intscanCode=OemKeyScan(c)&0x0ff; 关于c++-从WM_CHAR消息中获取扫描码,我们在St

windows - main(int argc, char** argv) 的荒谬值

我在旧的C++项目上启动了一个控制台应用程序。在main(intargc,char**argv)中设置断点开始program.exe-debug。根据调试器,argc变为32,argv中的字符串具有奇怪的随机值。继续执行时发生访问冲突,因为argv中的字符串指向无效值。这可能是什么原因造成的? 最佳答案 链接器设置了错误的入口点。对于普通的控制台应用程序,这应该是mainCRTStartup(调试器显示__tmainCRTStartup)。有一个无效的入口点导致main查看堆栈中“碰巧”的内容。发布这个是因为它不是很容易找到。

c# - 在 C# 中编码一个 char**

我正在与采用char**(即指向字符串的指针)的代码进行交互:intDoSomething(Whatever*handle,char**error);基本上,它需要一个状态句柄,如果出现问题,它会返回错误代码和可选的错误消息(内存是在外部分配的,并通过第二个函数释放。那部分我已经弄明白了:)).但是,我不确定如何在C#中处理in。我目前拥有的:[DllImport("mydll.dll",CallingConvention=CallingConvention.Cdecl)]privatestaticunsafeexternintDoSomething(IntPtrhandle,byte

c# - 为什么 TextWriter.Write(char) 不是抽象的?

TextWriter是一个抽象类,具有一个抽象函数-EncodingEncoding{get;}。实现还必须实现voidWrite(char),但这个函数不是抽象的-为什么?默认实现不执行任何对我来说没有意义的操作。 最佳答案 这是TextWriter的设计错误。根据Reflector,所有其他Write*方法都简化为Write(char)。文档说了类似的话。Write(char)应该是抽象的。没有注意到这一点的开发人员可能会被误导去创建一个大部分都有效的实现,但是当编写一个char(这并不常见)时,它可能什么都不做。令人惊讶的行为

c# - 使用 XmlSerializer 序列化 char 数据类型

我有一个类,其属性类型为char,如下所示[XmlRoot("Root")]publicclassTestClass{[XmlElement("Test",typeof(char))]publiccharTestProperty{get;set;}}当TestProperty的值为“N”时,如果我序列化TestClass,它将产生以下结果:78但我想要的是有跟随N是否可以不将TestProperty的类型更改为字符串? 最佳答案 不是AFAIK。不过你可以作弊:[XmlIgnore]publiccharTestProperty{ge