public delegate void KeyboardHookCaptureHandler(KeyboardHookEventArgs keyboardEvents);

public class KeyboardHookEventArgs : EventArgs {

    private Keys _pressedKey;
    private int _pressedKeyCode;

    public Keys PressedKey { get { return _pressedKey; } }
    public int PressedKeyCode { get { return _pressedKeyCode; } }

    public KeyboardHookEventArgs(int vkCode) {
        _pressedKey = (Keys)vkCode;
        _pressedKeyCode = vkCode;
    }
}

public class KeyboardHook {

    private delegate IntPtr LowLevelKeyboardProc(int nCode, IntPtr wParam, IntPtr lParam);

    public event KeyboardHookCaptureHandler KeyIntercepted;

    private const int WH_KEYBOARD_LL = 13;
    private const int WM_KEYDOWN = 0x0100;

    private LowLevelKeyboardProc _proc;
    private IntPtr _hookID = IntPtr.Zero;

    public KeyboardHook() {
        _proc = HookCallback;
        _hookID = SetHook(_proc);
    }
    public bool UnHookKey() {
        return UnhookWindowsHookEx(_hookID);
    }

    private IntPtr SetHook(LowLevelKeyboardProc proc) {
        using (Process curProcess = Process.GetCurrentProcess())
        using (ProcessModule curModule = curProcess.MainModule) {
            return SetWindowsHookEx(WH_KEYBOARD_LL, proc,
                GetModuleHandle(curModule.ModuleName), 0);
        }
    }

    private IntPtr HookCallback(
        int nCode, IntPtr wParam, IntPtr lParam) {
        if (nCode >= 0 && wParam == (IntPtr)WM_KEYDOWN) {
            int vkCode = Marshal.ReadInt32(lParam);
            KeyboardHookEventArgs keyHookArgs = new KeyboardHookEventArgs(vkCode);
            KeyIntercepted(keyHookArgs);
        }
        return CallNextHookEx(_hookID, nCode, wParam, lParam);
    }


    [DllImport("user32.dll", CharSet = CharSet.Auto, SetLastError = true)]
    private static extern IntPtr SetWindowsHookEx(int idHook,
        LowLevelKeyboardProc lpfn, IntPtr hMod, uint dwThreadId);

    [DllImport("user32.dll", CharSet = CharSet.Auto, SetLastError = true)]
    [return: MarshalAs(UnmanagedType.Bool)]
    private static extern bool UnhookWindowsHookEx(IntPtr hhk);

    [DllImport("user32.dll", CharSet = CharSet.Auto, SetLastError = true)]
    private static extern IntPtr CallNextHookEx(IntPtr hhk, int nCode,
        IntPtr wParam, IntPtr lParam);

    [DllImport("kernel32.dll", CharSet = CharSet.Auto, SetLastError = true)]
    private static extern IntPtr GetModuleHandle(string lpModuleName);
}


因此,即使它是程序的核心,我也不知道这段代码的含义。它钩住键盘按下事件,并将其发送到我的程序。任何人都可以在那里度过宝贵的时间并向我解释一些事情。我了解args类,因此您可以跳过。我最感兴趣的是什么是委托人,什么是IntPtr以及这两种方法以及它们逐行执行的操作。

谢谢,如果有人有时间

最佳答案

委托类型基本上指定了函数或方法的签名:这是一种将函数或方法捕获为对象的方式,以便以后可以调用该方法。因此,委托实例基本上是对函数或方法的引用。

IntPtr是操作系统本机指针-对一段非托管内存的不透明引用。

SetHook方法正在Windows中安装一个挂钩过程,以便将为系统中的每个键盘事件调用该挂钩过程。挂钩程序是什么?它是proc,是LowLevelKeyboardProc委托类型的实例。在这种情况下,始终将proc设置为引用您的HookCallback函数。因此,SetHook最终要做的是告诉Windows每当键盘事件发生时都调用HookCallback。

HookCallback正在解压缩与键盘事件关联的本机操作系统信息,并使用解压缩的数据引发KeyIntercepted事件。然后,它将控制权传递给链中的下一个挂钩,以防其他人想要挂钩键盘事件。

因此,所有这些的最终结果是,每次键盘事件发生时,此类都会引发KeyIntercepted事件。此类的用户可以提供KeyIntercepted事件处理程序来执行有用的操作,例如,将您的银行密码发送给您选择的犯罪集团... *笑*

关于c# - 半非托管代码与C#,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/2046079/

10-13 09:16