WINDOWS NT/2000下屏蔽CTRL+ALT+DEL完美解决方案
发布时间:2023-01-06 00:44:23
通过替换GINA DLL的方式很好地实现了在NT/2000下屏蔽CTRL+ALT+DEL的功能,下面为大家介绍下具体的实现原理及步骤,需要的朋友不要错过前言
在WINDOWS 9X环境中我们可以使用SystemParametersInfo (SPI_SCREENSAVERRUNNING, 1,NULL, 0);来屏蔽CTRL+ALT+DEL,但在NT/2000环境下却行不通,使使用WH_KEYBOARD_LL这个低级的键盘hook也无法拦截!笔者通过替换GINA DLL的方式很好地实现了在NT/2000下屏蔽CTRL+ALT+DEL的功能。
下载源代码 6K
一、原理
在NT/2000中交互式的登陆支持是由WinLogon调用GINA DLL实现的,GINA DLL提供了一个交互式的界面为用户登陆提供认证请求。在WinLogon初始化时,就向系统注册截获CTRL+ALT+DEL消息,所以其他程序就无法得到CTRL+ALT+DEL的消息。
WinLogon会和GINA DLL进行交互,缺省是MSGINA.DLL(在System32目录下)。微软同时也为我们提供的接口,自己
可以编GINA DLL来代替MSGINA.DLL。
WinLogon初始化时会创建3个桌面:
(1)、winlogon桌面:主要显示window 安全等界面,如你按下CTRL+ALT+DEL,登陆的界面等
(2)、应用程序桌面:我们平时见到的那个有我的电脑的界面
(3)、屏幕保护桌面:屏幕保护显示界面。
在用户登陆以后,按下CTRL+ALT+DEL键的时候,WinLogon回调用GINA DLL的输出函数:WlxLoggedOnSAS,
这时正处于winlogon桌面,我们只要直接将他转向应用程序桌面,系统就不会显示Windows安全那个界面,换一种说法
也就是用户按下CTRL+ALT+DEL后,不会起什么作用。当是我们在切换桌面的时候会出现屏幕闪动!
二、程序实现
GINA DLL要输出下列函数(winlogon会调用)
WlxActivateUserShell
WlxDisplayLockedNotice
WlxDisplaySASNotice
WlxDisplayStatusMessage
WlxGetStatusMessage
WlxInitialize
WlxIsLockOk
WlxIsLogoffOk
WlxLoggedOnSAS
WlxLoggedOutSAS
WlxLogoff
WlxNegotiate
WlxNetworkProviderLoad
WlxRemoveStatusMessage
WlxScreenSaverNotify
WlxShutdown
WlxStartApplication
WlxWkstaLockedSAS
为了简化编程,我们从MSGINA.DLL中动态获取上诉函数,在自定义的DLL中(以下称为NoReboot.DLL)中直接调用MSGINA.DLL
的函数即可。现在我们要处理的就是WlxLoggedOnSAS函数:
int WINAPI WlxLoggedOnSAS (
PVOID pWlxContext,
DWORD dwSasType,
PVOID pReserved)
{
HANDLE hMutex;
WriteInfo("WlxLoggedOnSAS \r\n"); //用于记录信息
if (dwSasType == WLX_SAS_TYPE_CTRL_ALT_DEL){ //屏蔽CTRL_ALT_DEL,也可以根据特定条件来决定是否要屏蔽
//我采用了Mutex来控制是否屏蔽,(注意:要用unicode)
hMutex = OpenMutex(MUTEX_ALL_ACCESS, FALSE, L"_ac952_z_cn_CTRL_ALT_DEL");
if (hMutex){
CloseHandle(hMutex);
WriteInfo("disble CTRL+ALT+DEL \r\n");
return WLX_SAS_ACTION_NONE; //将屏幕切换到应用程序桌面,屏蔽掉CTRL+ALT+DEL
}
else
WriteInfo("not disble CTRL+ALT+DEL \r\n");
}
return prcWlxLoggedOnSAS ( //这是我从MSGINA.DLL中获取的函数。
pWlxContext,
dwSasType,
pReserved);
}
我们要在自己的程序中调用hMutex = CreateMutex(NULL, FALSE, "_ac952_z_cn_CTRL_ALT_DEL");就可屏蔽CTRL+ALT+DEL。
三、安装和注意事项
在编写GIAN DLL中要注意,GINA DLL使用的是unicode。
GINA DLL的安装:
键名 : \HKEY_LOCAL_MACHINE\Software\Microsoft\Windows NT\CurrentVersion\Winlogon
变量名 : GinaDLL
变量类型 : [REG_SZ]
内容 : "你的GINA DLL的名称" 如:"NoReboot.DLL:
将你的GINA DLL(NoReboot.dll)拷贝到系统目录下(system32),重启机器,你的GINA DLL(NoReboot.dll)就会运行。
如果出现进不了你的系统,那你进入DOS后,将msgina.dll拷贝成你的GINA DLL(NoReboot.dll)就可进入了,或者进入安全模式,删除掉那个键值。


猜你喜欢
- Win10系统电脑桌面鼠标右键无法打开个性化设置是怎么回事?Win10电脑鼠标右键个性化设置打不开该如何解决?系统部落为大家解答。解决办法:
- 就在宣布 PowerShell 6.2的通用版本一周后, 微软宣布对所有平台上的PowerShell进行升级,新版本号将直接跳至PoweSh
- 在日常工作中,使用Excel统计数据,但对于统计函数,大部分人还是不熟悉的,不能轻松的使用函数完成统计工作。但是如果你用Excel数据透视表
- 360极速浏览器如何开启临时小号窗口?360极速浏览器是一款极速、安全的无缝双核浏览器,它有一个牛逼的功能,叫做“临时小号窗口”,同时也叫“
- 打印机是我们必不可少的办公设备之一,但是却有Win11用户想要使用打印机打印文件时,出现了电脑找不到打印机的情况,这该如何是好,导致出现这一
- Win11聚焦锁屏壁纸不更新了怎么解决?最近有用户反映这个问题,当给电脑设置聚焦后,系统就会自动更换锁屏壁纸,非常方便,那么聚焦后锁屏壁纸不
- ①启动Word2010,单击插入--表格,画出表格。 ②在表格输入一些数据,然后光标定位到后面的单元格,按下Ctr
- 【绘图工具】的对象是图形,【文本框工具】的对象是文本框,【图片工具】的对象是图片如图:这是【绘图工具】的工具按钮如图:这是【文本框工具】的工
- 在为对象添加动画(参考教程:PowerPoint 2013幻灯片中为对象添加动画效果的方法)后,按照默认参数运行的动画效果往往无法使用户满意
- 我们在使用Word2010编辑文档的过程中,常常需要版面要求设置段落与段落之间的距离,将WORD文档更美化一下,那么如何操作呢,在下面就由小
- Excel中累加该如何利用函数计算呢?下面是小编带来的关于excel 函数累加的教程,希望阅读过后对你有所启发!excel 函数累加的教程:
- 抖音emoji表情怎么弄到微信操作教学。在一些不同的软件中,它们的emoji表情会有一些差异。有用户发现抖音一些表情在微信里面是没有的,那么
- 在使用笔记本电脑时,如果开机情况下突然拔掉电源,屏幕就会随之变暗,这是Win7系统内置的电源计划在起作用,为的是帮我们节省电量,以便在没有电
- 快乐办公效率高 WPS2010 全新功能体验.国产办公软件中的佼佼者WPS Office,以其免费、小巧、简洁、特色插件的特点,已经逐渐被国
- Win11怎么使用建行网银?一些升级了Win11的朋友发现IE浏览器没有了,而我们登陆网易一般都需要支持ActiveX控件才能顺利运行,下面
- PPT已经成为了教学中不可或缺的数字生产力工具,相信不少老师也有将课件PPT分享给学生,帮助他们巩固学习的习惯。 不过,在微信等社交媒体上分
- 许多用户在使用电脑的时候都会进图BIOS进行一些系统的设置,但是对于一些BIOS来说,及基本都是英文,这样对于国内的用户来说十分的不友好。那
- 360浏览器的使用者非常多因为他很简洁且方便浏览速度也快,但是大多数的用户在使用的时候都会遇上一些问题,比如找不到设置在哪里今天就给大家带来
- 虽然我个人并不使用 macOS 的内建中文输入法,不过常在网路上看到有人抱怨在 macOS 打中文时老是卡卡的问题。如果你遇到这个问题,又刚
- 我们在使用WinXP系统操作电脑的时候,最怕的就是网络断掉的问题了,也就是电脑桌面右下角本地连接显示网络电缆没有插好的提示。若想知道导致这种