数据防泄漏 | 禁止PrintScreen键

Posted tosser

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数据防泄漏 | 禁止PrintScreen键相关的知识,希望对你有一定的参考价值。

       在数据防泄漏软件,通常会禁止 PrintScreen 键,防止通过截屏来将数据保存为图片而导致泄密。

       这类软件如果想要实现是比较简单的,但是想要将功能做的强大些,还是需要下功夫的。以前使用过一款数据防泄漏的软件,其中就有这个功能,它不但能禁止掉 PrintScreen 键,还能禁止其他的专业截屏软件。同样,禁止截屏软件的方法难点在于兼容性,就是不要影响正常的软件的运行。

?       这里介绍一些如何禁止 PrintScreen 键。其实很简单,只要安装低级键盘钩子(WH_KEYBOARD_LL)就可以搞定,普通的键盘钩子(WH_KEYBOARD)是无法过滤一些系统按键的。在低级键盘钩子的回调函数中,判断是否为 PrintScreen 键,如果是则直接返回 TRUE,如果不是则传递给钩子链的下一处。

 

      看代码吧!!!

 

 1 extern "C" __declspec(dllexport) BOOL SetHookOn()
 2 {
 3     if ( g_hHook != NULL )
 4     {
 5         return FALSE;
 6     }
 7     g_hHook = SetWindowsHookEx(WH_KEYBOARD_LL, LowLevelKeyboardProc, g_hIns, NULL);
 8     if ( NULL == g_hHook )
 9     {
10         MessageBox(NULL, "安装钩子出错 !", "error", MB_ICONSTOP);
11         return FALSE;
12     }
13 
14     return TRUE;
15 }
16 
17 extern "C" __declspec(dllexport) BOOL SetHookOff()
18 {    
19     if ( g_hHook == NULL )
20     {
21         return FALSE;
22     }
23     UnhookWindowsHookEx(g_hHook);
24     g_hHook = NULL;
25     return TRUE;
26 }
27 
28 LRESULT CALLBACK LowLevelKeyboardProc(
29             int nCode, WPARAM wParam, LPARAM lParam)
30 {
31     KBDLLHOOKSTRUCT *Key_Info = (KBDLLHOOKSTRUCT*)lParam;
32 
33     if ( HC_ACTION == nCode )
34     {
35         if ( WM_KEYDOWN == wParam || WM_SYSKEYDOWN == wParam )
36         {
37             if ( Key_Info->vkCode == VK_SNAPSHOT )
38             {
39                 return TRUE;
40             }
41         }
42     }
43 
44     return CallNextHookEx(g_hHook, nCode, wParam, lParam);
45 }

 

       代码量非常的短,是的……就是这短短的代码阻止了数据的泄漏。当然了,这样的保护对于一个攻击者,这个代码就无法保护数据了。对于一个攻击者,这种保护也就很脆弱了。任何的保护都有突破的办法,攻击无处不在,攻击者会尝试任何手段突破所有的保护。

 


 

欢迎大家关注微信公众号:“码农UP2U”

技术图片

以上是关于数据防泄漏 | 禁止PrintScreen键的主要内容,如果未能解决你的问题,请参考以下文章

数据防泄漏具备哪些特性?

数据防泄漏有哪些常见误区?

数据防泄漏有哪些常见误区?

关于PrintScreen的用法

printscreen键为何无法使用

数据防泄漏的重要性