android 全局hook_全局HOOK API (C#) 的实现

主要实现代码

代码:

[DllImport("user32.dll", CharSet = CharSet.Auto,

CallingConvention = CallingConvention.StdCall, SetLastError = true)]

private static extern int SetWindowsHookEx(

int idHook,

HookProc lpfn,

IntPtr hMod,

int dwThreadId);

[DllImport("user32.dll", CharSet = CharSet.Auto,

CallingConvention = CallingConvention.StdCall, SetLastError = true)]

private static extern int UnhookWindowsHookEx(int idHook);

[DllImport("user32.dll", CharSet = CharSet.Auto,

CallingConvention = CallingConvention.StdCall)]

private static extern int CallNextHookEx(

int idHook,

int nCode,

int wParam,

IntPtr lParam);

[DllImport("user32")]

private static extern int ToAscii(

int uVirtKey,

int uScanCode,

byte[] lpbKeyState,

byte[] lpwTransKey,

int fuState);

[DllImport("user32")]

private static extern int GetKeyboardState(byte[] pbKeyState);

[DllImport("user32.dll", CharSet = CharSet.Auto, CallingConvention = CallingConvention.StdCall)]

private static extern short GetKeyState(int vKey);

使用SetWindowsHookEx函数(API函数),指定一个Hook类型、自己的Hook过程是全局还是局部Hook,同时给出Hook过程的进入点,就可以轻松的安装自己的Hook。

代码:

// 创建鼠标实例.

MouseHookProcedure = new HookProc(MouseHookProc);

//安装 鼠标hook

hMouseHook = SetWindowsHookEx(

WH_MOUSE_LL,

MouseHookProcedure,

Marshal.GetHINSTANCE(

Assembly.GetExecutingAssembly().GetModules()[0]),

0);

// 创建键盘实例.

KeyboardHookProcedure = new HookProc(KeyboardHookProc);

//安装 键盘hook

hKeyboardHook = SetWindowsHookEx(

WH_KEYBOARD_LL,

KeyboardHookProcedure,

Marshal.GetHINSTANCE(

Assembly.GetExecutingAssembly().GetModules()[0]),

0);

卸载Hook UnhookWindowsHookEx()函数(API函数)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Python 中设置 Windows Hook,可以使用 ctypes 库调用 Windows API。具体步骤如下: 1. 导入 ctypes 库和 Windows API 函数: ```python import ctypes # 导入 Windows API 函数 user32 = ctypes.WinDLL('user32') kernel32 = ctypes.WinDLL('kernel32') ``` 2. 定义 Windows Hook 回调函数: ```python # 定义回调函数类型 HOOKPROC = ctypes.WINFUNCTYPE(ctypes.c_int, ctypes.c_int, ctypes.wintypes.WPARAM, ctypes.wintypes.LPARAM) # 定义回调函数 def hook_callback(nCode, wParam, lParam): # 处理钩子消息 return user32.CallNextHookEx(hook_id, nCode, wParam, lParam) ``` 3. 安装 Hook: ```python # 安装 Hook hook_id = user32.SetWindowsHookExW( 13, # WH_KEYBOARD_LL 钩子类型 HOOKPROC(hook_callback), # 回调函数 kernel32.GetModuleHandleW(None), # 模块句柄 0 # 线程 ID,0 表示钩子适用于所有线程 ) ``` 4. 处理消息循环: ```python # 处理消息循环 msg = ctypes.wintypes.MSG() while user32.GetMessageW(ctypes.byref(msg), None, 0, 0) != 0: user32.TranslateMessage(ctypes.byref(msg)) user32.DispatchMessageW(ctypes.byref(msg)) ``` 5. 卸载 Hook: ```python # 卸载 Hook user32.UnhookWindowsHookEx(hook_id) ``` 完整代码示例: ```python import ctypes import ctypes.wintypes # 导入 Windows API 函数 user32 = ctypes.WinDLL('user32') kernel32 = ctypes.WinDLL('kernel32') # 定义回调函数类型 HOOKPROC = ctypes.WINFUNCTYPE(ctypes.c_int, ctypes.c_int, ctypes.wintypes.WPARAM, ctypes.wintypes.LPARAM) # 定义回调函数 def hook_callback(nCode, wParam, lParam): # 处理钩子消息 return user32.CallNextHookEx(hook_id, nCode, wParam, lParam) # 安装 Hook hook_id = user32.SetWindowsHookExW( 13, # WH_KEYBOARD_LL 钩子类型 HOOKPROC(hook_callback), # 回调函数 kernel32.GetModuleHandleW(None), # 模块句柄 0 # 线程 ID,0 表示钩子适用于所有线程 ) # 处理消息循环 msg = ctypes.wintypes.MSG() while user32.GetMessageW(ctypes.byref(msg), None, 0, 0) != 0: user32.TranslateMessage(ctypes.byref(msg)) user32.DispatchMessageW(ctypes.byref(msg)) # 卸载 Hook user32.UnhookWindowsHookEx(hook_id) ``` 注意:Windows Hook 需要在 Windows 操作系统上运行,而且需要管理员权限。同时,Hook 回调函数的处理时间应该尽量短,以免影响系统性能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值