钩子其实就是调用一下API而已:
1、安装钩子:
SetWindowsHookEx
函数原形:HHOOK SetWindowsHookEx(
int idHook, // 钩子类型,
HOOKPROC lpfn, // 钩子函数地址
INSTANCE hMod, // 钩子所在的实例的句柄,
DWORD dwThreadId // 钩子所监视的线程的线程号
)
hMod: 对于线程序钩子,参数传NULL;
对于系统钩子:参数为钩子DLL的句柄
dwThreadId:对于全局钩子,该参数为NULL。
钩子类型用WH_CALLWNDPROC=4(发送到窗口的消息。由SendMessage触发)
返回:成功:返回SetWindowsHookEx返回所安装的钩子句柄;
失败:NULL;
2、回调,你要截获消息就在这里进行:
LRESULT WINAPI MyHookProc(
int nCode , // 指定是否需要处理该消息
WPARAM wParam, // 包含该消息的附加消息
LPARAM lParam // 包含该消息的附加消息
)
3、调用下一个钩子
LRESULT CallNextHookEx(
HHOOK hhk, // 是您自己的钩子函数的句柄。用该句柄可以遍历钩子链
int nCode, // 把传入的参数简单传给CallNextHookEx即可
WPARAM wParam, // 把传入的参数简单传给CallNextHookEx即可
LPARAM lParam // 把传入的参数简单传给CallNextHookEx即可
);
4、用完后记得卸载钩子哦,要不然你的系统会变得奇慢无比!
BOOL UnhookWindowsHookEx(
HHOOK hhk // 要卸载的钩子句柄。
)
把上面这些API用C#封装一下,就可以直接用了!
给个线程钩子的例子吧(两个Form都在同一个线程中运行):
using System.Runtime.InteropServices;
public class Form1 : System.Windows.Forms.Form
{
...
//定义委托(钩子函数,用于回调)
public delegate int HookProc(int code, IntPtr wparam, ref CWPSTRUCT cwp);
//安装钩子的函数
[DllImport("User32.dll",CharSet = CharSet.Auto)]
public static extern IntPtr SetWindowsHookEx(int type, HookProc hook, IntPtr instance, int threadID);
//调用下一个钩子的函数
[DllImport("User32.dll",CharSet = CharSet.Auto)]
public static extern int CallNextHookEx(IntPtr hookHandle, int code, IntPtr wparam, ref CWPSTRUCT cwp);
//卸载钩子
[DllImport("User32.dll",CharSet = CharSet.Auto)]
public static extern bool UnhookWindowsHookEx(IntPtr hookHandle);
//获取窗体线程ID
DllImport("User32.dll",CharSet = CharSet.Auto)]
public static extern int GetWindowThreadProcessId(IntPtr hwnd, int ID);
private HookProc hookProc;
private IntPtr hookHandle = IntPtr.Zero;
public Form1()
{
....
//挂接钩子处理方法
this.hookProc = new HookProc(myhookproc);
}
//开始拦截
private bool StartHook()
{
Form2 f=new Form2();
f.Show();//加上这个
//安装钩子,拦截系统向Form2发出的消息
this.hookHandle = SetWindowsHookEx(4, hookProc, IntPtr.Zero ,GetWindowThreadProcessId(f.Handle,0));
return (this.hookHandle != 0);
}
//停止拦截
private bool StopHook()
{
return UnhookWindowsHookEx(this.hookHandle);
}
//钩子处理函数,在这里拦截消息并做处理
private int myhookproc(int code, IntPtr wparam, ref CWPSTRUCT cwp)
{
switch(code)
{
case 0:
switch(cwp.message)
{
case 0x0000F://WM_PAINT,拦截WM_PAINT消息
//do something
break;
}
break;
}
return CallNextHookEx(hookHandle,code,wparam, ref cwp);
}
[StructLayout(LayoutKind.Sequential)]
public struct CWPSTRUCT
{
public IntPtr lparam;
public IntPtr wparam;
public int message;
public IntPtr hwnd;
}
}
public class Form2 : System.Windows.Forms.Form
{
....
}
分享到:
相关推荐
在C#中,我们可以使用钩子函数来拦截Windows操作系统产生的一些事件,例如鼠标、键盘或者窗口事件等。其中,窗口消息钩子(WH_CALLWNDPROC)是一种比较常见的钩子函数,它能够拦截窗口消息,并允许应用程序修改或阻止...
设置钩子函数的委托Callback,如果拦截到任务管理器关闭消息,则在控制台输出一条信息,并返回IntPtr.Zero来拦截消息 在窗体关闭时,调用UnhookWindowsHookEx来卸载钩子 使用DllImport引入Windows API,包括...
C#实现键盘鼠标全局钩子 VS2013,可编译运行,带DEMO 可全局拦截鼠标单击/双击/滚动事件 可全局拦截键盘按键事件 可锁定键盘鼠标输入,比如锁屏! 该代码无法屏蔽Ctrl +alt +delete 需要实现所有拦截,请参考相关...
vs2013 c# winform ,PreFilterMessage拦截本程序内的鼠标消息,获取鼠标与键盘钩子获取鼠标与键盘消息,或者取消键盘消息
很不错的C#多线程消息处理例子,UI界面,给出了后台线程向界面传递信息以及UI线程解析信息的完整过程。值得一看!
c#钩子获取键盘消息 这个是别人写的,我拿来试了试,虽然依然不是很明白,但既然已实现功能,就放在这里吧。
串口通信的实现,编程环境为C#,实现技术采用了多线程方式
C# Winform中使用SendMessage消息发送拦截,WndProc消息处理拦截。小案例。
c# 多线程任务中结束全部线程
c# window服务多线程实例
c#编写串口通讯代码多线程实现,逻辑与界面分离。发送与接收都为单独线程
C#的多线程机制初探(1)C#的多线程机制初探(1)C#的多线程机制初探(1)C#的多线程机制初探(1)C#的多线程机制初探(1)C#的多线程机制初探(1)C#的多线程机制初探(1)C#的多线程机制初探(1)C#的多线程机制初探(1)
C#中的多线程C#中的多线程C#中的多线程C#中的多线程C#中的多线程
Hook(钩子)是WINDOWS提供的一种消息处理机制平台,是指在程序正常运 ...本实例为通过C#屏蔽键盘、利用HOOK钩子屏蔽ctrl+alt+delete组合键的示例源码,可直接编译。 示例支持屏蔽按键、解除屏蔽。
c# 钩子函数 屏蔽键盘
C#键盘勾子(Hook)拦截器,屏蔽键盘活动 钩子(Hook),是Windows消息处理机制的一个平台,应用程序可以在上面设置子程以监视指定窗口的某种消息,而且所监视的窗口可以是其他进程所创建的。当消息到达后,在目标窗口...
C# 多线程基本于httpwebrequest实现的下载功能 每个线程均可以通过事件追踪情况
C#多线程实现定时器
C#多线程复制代码: 1.运用线程和线程池的知识 2.可以实现 限制线程的数量 进行上传 3.用到FileStream类的读写功能 总之 大家可以参考一下!
通过多线程的方式实现了UDP收发数据 可以快速学习UDP通讯原理应进行实际应用