C# 计算机锁定时侦听全局键盘事件

C# 计算机锁定时侦听全局键盘事件,c#,keyboard,globalevent,C#,Keyboard,Globalevent,我正在试验键盘事件以及如何处理它们,我发现了很多教程和开源库,可以在其他进程中侦听键盘事件。我想出了一个想法,创建一个简单的“黑客”来锁定计算机,然后监听键盘事件。我想我可以强迫用户输入他们的密码来解锁他们的电脑,然后我会听用户的输入,从而获得指定的密码。以下是我在互联网上找到的简单示例代码,它将侦听全局键盘事件: using System; using System.Diagnostics; using System.Windows.Forms; using System.Runtime.In

我正在试验键盘事件以及如何处理它们,我发现了很多教程和开源库,可以在其他进程中侦听键盘事件。我想出了一个想法,创建一个简单的“黑客”来锁定计算机,然后监听键盘事件。我想我可以强迫用户输入他们的密码来解锁他们的电脑,然后我会听用户的输入,从而获得指定的密码。以下是我在互联网上找到的简单示例代码,它将侦听全局键盘事件:

using System;
using System.Diagnostics;
using System.Windows.Forms;
using System.Runtime.InteropServices;

class InterceptKeys
{
    private const int WH_KEYBOARD_LL = 13;
    private const int WM_KEYDOWN = 0x0100;
    private static LowLevelKeyboardProc _proc = HookCallback;
    private static IntPtr _hookID = IntPtr.Zero;

    public static void Main()
    {
        _hookID = SetHook(_proc);
        Application.Run();
        UnhookWindowsHookEx(_hookID);
    }

    private static 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 delegate IntPtr LowLevelKeyboardProc(
        int nCode, IntPtr wParam, IntPtr lParam);

    private static IntPtr HookCallback(
        int nCode, IntPtr wParam, IntPtr lParam)
    {
        if (nCode >= 0 && wParam == (IntPtr)WM_KEYDOWN)
        {
            int vkCode = Marshal.ReadInt32(lParam);
            Console.WriteLine((Keys)vkCode);
        }
        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);
}

这样做效果很好,但出于某种原因,当计算机被锁定时,听键盘输入时似乎会出现异常?我不知道为什么它不起作用,也许是安全问题。无论如何,如果你能做到这一点,那就太棒了。

如果这是在Windows上,锁定的屏幕实际上是不同的,不属于交互用户,因此交互用户不能以任何方式与之交互(作为安全措施)。要与锁屏交互并登录,请查看创建一个

如果这是在Windows上,则锁屏实际上是不同的,不属于交互用户,因此交互用户无法以任何方式与其交互(作为安全措施)。要与锁屏交互并登录,请查看创建一个

如果这是在Windows上,则锁屏实际上是不同的,不属于交互用户,因此交互用户无法以任何方式与其交互(作为安全措施)。要与锁屏交互并登录,请查看创建一个

如果这是在Windows上,则锁屏实际上是不同的,不属于交互用户,因此交互用户无法以任何方式与其交互(作为安全措施)。要与锁屏交互并登录,请查看创建一个

这是一个安全问题。“我怀疑有没有办法绕过它而不入侵操作系统。”罗伯塔维感谢你的快速回答。但是,如果您运行另一个伪造的相同应用程序或该应用程序的破解版本,然后让用户认为计算机已锁定,那么这可能实现吗?给我一个信用卡号码(以及背面的安全代码),我会告诉您答案。这是一个安全问题。“我怀疑有没有办法绕过它而不入侵操作系统。”罗伯塔维感谢你的快速回答。但是,如果您运行另一个伪造的相同应用程序或该应用程序的破解版本,然后让用户认为计算机已锁定,那么这可能实现吗?给我一个信用卡号码(以及背面的安全代码),我会告诉您答案。这是一个安全问题。“我怀疑有没有办法绕过它而不入侵操作系统。”罗伯塔维感谢你的快速回答。但是,如果您运行另一个伪造的相同应用程序或该应用程序的破解版本,然后让用户认为计算机已锁定,那么这可能实现吗?给我一个信用卡号码(以及背面的安全代码),我会告诉您答案。这是一个安全问题。“我怀疑有没有办法绕过它而不入侵操作系统。”罗伯塔维感谢你的快速回答。但是,如果您运行另一个伪造的相同应用程序或该应用程序的破解版本,然后让用户认为计算机已被锁定,那么这是否可能实现?请给我一个信用卡号码(以及背面的安全代码),我会告诉您答案。