hook钩子例子

一般软件都要输入序列号(SN),而大家平时用的最多的恐怕是盗版软件,通常盗版软件的序列号(SN)都保存成:XXXXX-XXXXX-XXXX-XXXX的形式。

  既然是要处理复制的序列号,那么我们肯定要用到和剪贴板相关的东西了。剪贴板,还好这个我以前在C#中用过N次了,不用再查windows api了。C#里面本来就提供了Clipboard这个类。

  于是就用到了string Clipboard.GetText()这个静态方法,将刚才复制的带-的序列号取出来,然后用个string类型的变量strKeys保存在我的程序中,以便使用。

  第一步,从剪贴板里面取数据,我们就完成了。

  接着,我们该考虑怎么处理我们的数据了,我们的数据最后是要写到几个连续的文本框中的,那么我们可以考虑通过String.Split(char[],string splitoption)这个方法将序列号分割成几个子字符串,然后再通过windows api讲文本输出到相应的textbox句柄上。但是这样做无疑增加了程序的难度,几个连续的文本框的切换,使用Tab键就能做到了,然后将文本输出到文本框中,直接让键盘打出来就ok了。那么很明显,我们只需要将我们要按的键模拟出来就行了,这个时候我首先想到的是windows api中键盘模拟事件keybd_event,于是我开始在MSDN中查询keybd_event方法,方法中有个KEYEVENTF_KEYUP这个参数,但是我不知道他相应的值,于是我开始查找这个长整形的值。但是始终都找不到,就在我在MSDN中查找KEYUP相关的东西的时候,我突然发现了System.Windows.Form.SendKeys这个类。原来.net framework已经将keybd_event这个非托管对象的方法封装到SendKeys这个类中了,直接使用SendKeys这个类就可以模拟键盘操作了。

  再查询Tab键的写法就是{Tab}。

  那么我只要将原来文本strKeys中的'-'全部转换成{Tab}然后再交给SendKeys这个类来处理,这个程序就基本完成了。

  于是有了
strKeys.Replace("-", "{TAB}");
SendKeys.Send(strKeys);

这两行代码。

  这样就有了我的程序的主过程:
private void ProcessHotkey()//主处理程序
{
    strKeys = Clipboard.GetText();
    strKeys.Replace("-", "{TAB}");
    SendKeys.Send(strKeys);
}

    但是我们怎么通过快捷键来触发,来完成这个过程了。

  于是我开始在百度和MSDN查找相关处理全局快捷键的windows api的资料。

  要设置快捷键必须使用user32.dll下面的两个方法。
BOOL RegisterHotKey(
    HWND hWnd,
    int id,
    UINT fsModifiers,
    UINT vk
);


BOOL UnregisterHotKey(
   HWND hWnd,
   int id
);

转换成C#代码,那么首先就要引用命名空间System.Runtime.InteropServices;来加载非托管类user32.dll。于是有了:
[DllImport("user32.dll", SetLastError = true)]
public static extern bool RegisterHotKey(
    IntPtr hWnd, // handle to window 
    int id, // hot key identifier 
    KeyModifiers fsModifiers, // key-modifier options 
    Keys vk // virtual-key code 
);

[DllImport("user32.dll", SetLastError = true)]
public static extern bool UnregisterHotKey(
    IntPtr hWnd, // handle to window 
    int id // hot key identifier 
);


[Flags()]
public enum KeyModifiers
{
    None = 0,
    Alt = 1,
    Control = 2,
    Shift = 4,
    Windows = 8
}

  这是注册和卸载全局快捷键的方法,那么我们只需要在Form_Load的时候加上注册快捷键的语句,在FormClosing的时候卸载全局快捷键。同时,为了保证剪贴板的内容不受到其他程序调用剪贴板的干扰,在Form_Load的时候,我先将剪贴板里面的内容清空。

  于是有了:
private void Form1_Load(object sender, System.EventArgs e)
{
    label2.AutoSize = true;

    Clipboard.Clear();//先清空剪贴板防止剪贴板里面先复制了其他内容
    RegisterHotKey(Handle, 100, 0, Keys.F10);
}

private void Form1_FormClosing(object sender, FormClosingEventArgs e)
{
    UnregisterHotKey(Handle, 100);//卸载快捷键
}

  那么我们在别的窗口,怎么让按了快捷键以后调用我的主过程ProcessHotkey()呢?

  那么我们就必须重写WndProc()方法,通过监视系统消息,来调用过程:(关注)
protected override void WndProc(ref Message m)//监视Windows消息
{
    const int WM_HOTKEY = 0x0312;//按快捷键
    switch (m.Msg)
    {
    case WM_HOTKEY:
        ProcessHotkey();//调用主处理程序
        break;
    }
    base.WndProc(ref m);
}

  这样我的程序就完成了。  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值