键盘输入的限制

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_39674002/article/details/83244803

前言

最近事情挺多的,各种考试,各种复习头都大了,不过在空闲之余也琢磨了一下,这个机房系统的相关需求,后来想着将登录界面写成类似于电脑锁屏的样子.就是说没有账号和密码就不能对电脑进行操作,想着这个功能应该是挺好实现的,然后就开始动手写了.当然我现在这个水平自己去原创的写还是有点小困难的,所以就借助了咱们这个时代最伟大的工具,互联网来进行的学习和提高.

正文

首先是禁用Alt+F4
这个相对来说容易理解也比较好写代码如下

// 禁用alt + f4:
        //重写
        protected override CreateParams CreateParams
        {
            get
            {
                const int CS_NOCLOSE = 0x200;
                CreateParams cp = base.CreateParams;
                cp.ClassStyle = cp.ClassStyle | CS_NOCLOSE;
                return cp;
            }

        }

然后就是禁用键盘的其他快捷键,这个程序比较复杂,目前的我还没有彻底理解原理是怎么回事,不过不影响我去使用相关功能,代码源自网络,大家有兴趣的可以研究研究.
首先在登录窗体加载事件中启动禁用键盘事件

//键盘事件
        Hook h = new Hook();
 private void Login_Load(object sender, EventArgs e)
        {
            h.Hook_Start();//禁用键盘开始           
        }
public class Hook
        {
            public delegate int HookProc(int nCode, int wParam, IntPtr lParam);
            static int hHook = 0;
            public const int WH_KEYBOARD_LL = 13;
            //LowLevel键盘截获,如果是WH_KEYBOARD=2,并不能对系统键盘截取,Acrobat Reader会在你截取之前获得键盘。 
            HookProc KeyBoardHookProcedure;
            //键盘Hook结构函数 
            [StructLayout(LayoutKind.Sequential)]
            public class KeyBoardHookStruct
            {
                public int vkCode;
                public int scanCode;
                public int flags;
                public int time;
                public int dwExtraInfo;
            }
            #region DllImport
            //设置钩子 
            [DllImport("user32.dll")]
            public static extern int SetWindowsHookEx(int idHook, HookProc lpfn, IntPtr hInstance, int threadId);
            [DllImport("user32.dll", CharSet = CharSet.Auto, CallingConvention = CallingConvention.StdCall)]
            //抽掉钩子 
            public static extern bool UnhookWindowsHookEx(int idHook);
            [DllImport("user32.dll")]
            //调用下一个钩子 
            public static extern int CallNextHookEx(int idHook, int nCode, int wParam, IntPtr lParam);

            [DllImport("kernel32.dll")]
            public static extern int GetCurrentThreadId();

            [DllImport("kernel32.dll")]
            public static extern IntPtr GetModuleHandle(string name);

            #endregion

            #region 自定义事件
            public void Hook_Start()
            {
                // 安装键盘钩子 
                if (hHook == 0)
                {
                    KeyBoardHookProcedure = new HookProc(KeyBoardHookProc);


                    hHook = SetWindowsHookEx(WH_KEYBOARD_LL,
                               KeyBoardHookProcedure,
                              GetModuleHandle(Process.GetCurrentProcess().MainModule.ModuleName), 0);
                    //如果设置钩子失败. 
                    if (hHook == 0)
                    {
                        Hook_Clear();
                        throw new Exception();
                    }
                    else
                    {

                    }
                }
            }

            //取消钩子事件 
            public void Hook_Clear()
            {
                bool retKeyboard = true;
                if (hHook != 0)
                {
                    retKeyboard = UnhookWindowsHookEx(hHook);
                    hHook = 0;
                }
                //如果去掉钩子失败. 
                if (!retKeyboard) throw new Exception("UnhookWindowsHookEx failed.");
            }

            //这里可以添加自己想要的信息处理 
            public static int KeyBoardHookProc(int nCode, int wParam, IntPtr lParam)

           {

                if (nCode >= 0)
                {
                    KeyBoardHookStruct kbh = (KeyBoardHookStruct)Marshal.PtrToStructure(lParam, typeof(KeyBoardHookStruct));

                    int v = kbh.vkCode;
                    switch (v)
                    {
                        case 27://ESC键
                        case 91://左徽标键
                        case 92://右徽标键
                        case 93://鼠标右键快捷键
                        case 164://
                        case 9://TAB键
                        case 10://Shift键
                        case 17://Ctrl键
                        case 18://Alt键
                        case 162://
                        case 229://.键
                        case 110://全角.键
                        case 46://Delete键
                        case 115://F4键
                        case 241://F1键
                        
                            return 1;
                    }
                }
                return CallNextHookEx(hHook, nCode, wParam, lParam);
            }
            #endregion

        }

然后就是禁用任务管理器了,不过这个功能有点小问题查了好多的资料也没有完美的解决这个问题.
就写了一个禁用任务管理器的代码,主要就是杀线程的.

//禁用任务管理器
        protected override bool ProcessKeyEventArgs(ref Message m)
        {
            KillTaskmgr();
            return base.ProcessKeyEventArgs(ref m);
        }


        //禁用任务管理器:开个线程扼杀任务管理器
        private void KillTaskmgr()
        {
            while (true)
            {
                Process[] sum = Process.GetProcesses();
                foreach (Process p in sum)
                {
                    if (p.ProcessName == "taskmgr" || p.ProcessName == "cmd")
                        try
                        {
                            p.Kill();
                        }
                        catch
                        {
                            ;
                        }
                }
            }
        }

结束语

大概的程序过程就是这样了,虽然不够完美终归是做出了点东西.在这个基础上继续努力去追求完美.这样才是合理的.我相信这些遗留的问题早晚都是能解决的.毕竟大家都这么努力是吧.哈哈哈哈哈
好了今天就写到这吧!!!接着去奋斗了

猜你喜欢

转载自blog.csdn.net/qq_39674002/article/details/83244803