Ring3下无驱动移除winlogon.exe进程ctrl+alt+del,win+u,win+l三个系统热键,非屏蔽热键(子类化SAS 窗口)
随手而作,纯粹技术研究,没什么实际意义。
打开xuetr,正常情况下.winlogon.exe注册了三个热键。
ctrl+alt+del,win+u,win+l三个。
这三个键用SetWindowsHookEx()函数,使用键盘钩子也屏蔽不了。
我们先把UnregisterSystemHotKey.dll解压出来,放到任意目录.
比如E盘根目录,就运行
- rundll32 E:\UnregisterSystemHotKey.dll,Hook
再打开xuetr看下,Winlogo.exe进程注册的热键都没有了.
- #include <windows.h>
- #include <process.h>
- #include <tchar.h>
- #include <stdio.h>
- #include <shlwapi.h>
- #include <psapi.h>
- #pragma comment(lib, "psapi.lib")
- #pragma comment(lib, "shlwapi.lib")
- TCHAR ModuleFile[MAX_PATH];
- TCHAR szText[128] = {0};
- WNDPROC OldWindowProc;
- HWND hWinLogon;
- HMODULE hDll;
- LRESULT CALLBACK NewWindowProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
- {
- if (message == WM_NULL)
- {
- ::UnregisterHotKey(hWnd, 0); //Ctrl+Alt+delete
- ::UnregisterHotKey(hWnd, 4); //Ctrl+Shift+Esc
- ::UnregisterHotKey(hWnd, 5); //Win+L
- ::UnregisterHotKey(hWnd, 6); //Win+U
- ::SetWindowLongPtr(hWnd, GWL_WNDPROC, (LONG)OldWindowProc);
- return 1;
- }
- return CallWindowProc(OldWindowProc, hWnd, message, wParam, lParam);
- }
- BOOL WINAPI EnablePrivileges()
- {
- HANDLE hToken;
- TOKEN_PRIVILEGES tkp;
- if (!OpenProcessToken(GetCurrentProcess(),
- TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY, &hToken))
- return( FALSE );
- LookupPrivilegeValue(NULL, SE_DEBUG_NAME,
- &tkp.Privileges[0].Luid);
- tkp.PrivilegeCount = 1;
- tkp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
- AdjustTokenPrivileges(hToken, FALSE, &tkp, 0,
- (PTOKEN_PRIVILEGES)NULL, 0);
- if (GetLastError() != ERROR_SUCCESS)
- return FALSE;
- return TRUE;
- }
- BOOL CALLBACK lpEnumWindowsProc(HWND hwnd, LPARAM lParam)
- {
- if (IsWindow(hwnd))
- {
- ::GetWindowText(hwnd, szText, _countof(szText));
- if (!_tcscmp(szText, TEXT("SAS window")))
- {
- hWinLogon = hwnd;
- OldWindowProc = (WNDPROC)::SetWindowLongPtr(hwnd, GWL_WNDPROC, (LONG)NewWindowProc);
- PostMessage(hwnd, WM_NULL, 0, 0);
- return FALSE;
- }
- }
- return TRUE;
- }
- UINT _stdcall FreeSelfProc(void *Arg)
- {
- FreeLibraryAndExitThread(hDll, 0);
- return 1;
- }
- BOOL WINAPI DllMain(HINSTANCE hDllHandle, DWORD nReason, LPVOID Reserved)
- {
- switch ( nReason )
- {
- case DLL_PROCESS_ATTACH:
- hDll = hDllHandle;
- GetModuleFileName(NULL, ModuleFile, _countof(ModuleFile));
- EnablePrivileges();
- if (StrStrI(ModuleFile, TEXT("winlogon.exe")))
- {
- HANDLE hThread;
- UINT ThreadId;
- HDESK hWinLogon = OpenDesktop(TEXT("Winlogon"), 0, FALSE, GENERIC_ALL);
- ::EnumDesktopWindows(hWinLogon, lpEnumWindowsProc, NULL);
- CloseDesktop(hWinLogon);
- hThread = (HANDLE)_beginthreadex(NULL, NULL, &FreeSelfProc, 0, 0, &ThreadId);
- WaitForSingleObject(hThread, INFINITE);
- CloseHandle(hThread);
- }
- else
- {
- DWORD dwProcessId = 0;
- HANDLE hProcess = 0;
- DWORD ProcessList[512], cbNeeded, cProcess;
- TCHAR szFileName[256];
- EnumProcesses(ProcessList, sizeof(ProcessList), &cbNeeded);
- cProcess = cbNeeded/sizeof(DWORD);
- for (UINT i=0; i<cProcess; i++)
- {
- if (ProcessList[i] != 0)
- {
- hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, ProcessList[i]);
- if (hProcess)
- {
- GetModuleBaseName(hProcess, NULL, szFileName, _countof(szFileName));
- if (!_tcsicmp(szFileName, TEXT("winlogon.exe")))
- {
- dwProcessId = ProcessList[i];
- break;
- }
- }
- }
- }
- if (dwProcessId)
- {
- hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, dwProcessId);
- }
- if (!hProcess)
- {
- return 0;
- }
- LPVOID Param = VirtualAllocEx(hProcess, 0, 512, MEM_COMMIT, PAGE_READWRITE);
- if (!Param)
- {
- MessageBox(NULL, TEXT("申请内存失败"), TEXT("申请内存失败"), MB_ICONWARNING);
- return 0;
- }
- GetModuleFileName(hDllHandle, ModuleFile, _countof(ModuleFile));
- if (!WriteProcessMemory(hProcess, Param, (LPVOID)ModuleFile, 256, NULL))
- {
- MessageBox(NULL, TEXT("写入内存失败"), TEXT("写入内存失败"), MB_ICONWARNING);
- return 0;
- }
- HANDLE hThread = CreateRemoteThread(hProcess,
- NULL,
- NULL,
- (LPTHREAD_START_ROUTINE)GetProcAddress(GetModuleHandle(TEXT("kernel32.dll")), "LoadLibraryW"),
- Param,
- NULL,
- NULL);
- if (hThread)
- {
- WaitForSingleObject(hThread, INFINITE);
- }
- else
- {
- TCHAR sztmp[1024];
- _stprintf_s(sztmp, _countof(sztmp), TEXT("创建远程线程失败, 错误代码:%d, dll=%s"), GetLastError(), ModuleFile);
- MessageBox(NULL, sztmp, TEXT("创建远程线程失败"), MB_ICONWARNING);
- return 0;
- }
- VirtualFreeEx(hProcess, Param , 0, MEM_RELEASE);
- CloseHandle(hThread);
- CloseHandle(hProcess);
- }
- break;
- case DLL_THREAD_ATTACH:
- break;
- case DLL_THREAD_DETACH:
- break;
- case DLL_PROCESS_DETACH:
- ::SetWindowLongPtr(hWinLogon, GWL_WNDPROC, (LONG)OldWindowProc);
- break;
- default:
- break;
- }
- return 1;
- }
- EXTERN_C __declspec(dllexport) int Hook(void)
- {
- return 1;
- }
http://blog.csdn.net/zwfgdlc/article/details/6609591
我仔细看了看,突然想到。这不是传说很久的SAS子类化吗?居然忘记了
http://topic.csdn.net/u/20090402/11/d3e27441-cfcc-45d8-a0b2-1164fc3dd777.html
Ring3下无驱动移除winlogon.exe进程ctrl+alt+del,win+u,win+l三个系统热键,非屏蔽热键(子类化SAS 窗口)的更多相关文章
- 关于csrss.exe和winlogon.exe进程多、占用CPU高的解决办法,有人在暴力破解
关于csrss.exe和winlogon.exe进程多.占用CPU高的解决办法 最近VPS的CPU一直处在100%左右,后台管理上去经常打不开,后来发现上远程都要好半天才反映过来,看到任务管理器有多个 ...
- 关于csrss.exe和winlogon.exe进程多、占用CPU高的解决办法
原地址 http://blog.sina.com.cn/s/blog_912e77480101nuif.html 最近VPS的CPU一直处在100%左右,后台管理上去经常打不开,后来发现上远程都要 ...
- win7下禁用ctrl alt del +上下左右键
1.控制面板 2.屏幕分辨率 3.高级设置 4.英特尔图形和媒体控制面板 5.图形属性 6.选项和支持 7.快捷键管理器 8.去掉启动前的勾
- Mac下通过远程桌面向Windows发送Ctrl+Alt+Delete
今天在Mac中通过远程桌面给Windows安装Git Extensions,在安装程序自动关闭资源管理器时,Windows无响应,桌面显示黑屏.于是,想通过Ctrl+Alt+Delete快捷键调出对话 ...
- Ring3下干净的强行删除文件
在某公司实习完,再次回到寝室.还是在学校好. 实习期间的给我的任务就是为项目添加一个强行删除的模块. 背景是硬盘上存储空间不够时,需要删掉老的文件,如果这时后,老的文件被打开了,没有关掉,就无法删除. ...
- 树莓派3b无驱动打印
Linux系统下很少有对打印机做驱动支持,自己做起来又有非常麻烦,还好大多数打印机都能够支持escpos协议,因此我们可以做到无驱动打印. 1.安装python-usb库 git clone http ...
- winlogon.exe应用程序错误怎么办
winlogon.exe应用程序错误 求解决办法,重装,还原一定能解决就不要说了,我要其他办法 最佳答案 winlogon.exe 是控制你的系统登陆的程序,是系统绝对核心进程,用来管理系统用户登陆! ...
- Ubuntu16.04下nvidia驱动+nvidia-docker+cuda9+cudnn7安装
一.宿主机安装nvidia驱动 打开终端,先删除旧的驱动: sudo apt-get purge nvidia* 禁用自带的 nouveau nvidia驱动 sudo gedit /etc/modp ...
- Linux的.a、.so和.o文件 对比 window下的dll,lib,exe文件
连续几天终于将一个又一个问题解决了,这里说其中一个问题 描述问题:使用多线程pthread的时候,(我用的IDE,CODEBOLCKS)编译后发现直接弹出窗口,程序还没有被Build..巴拉巴拉,然后 ...
随机推荐
- 微信上传素材 {"errcode":41005,"errmsg":"media data missing"} 解决方法和思路
哎lol 连跪两把 就来写写博客 今天遇到一个问题 ,微信公众号开发上传素材是提示报错 41005 errcode":41005,"errmsg":&q ...
- 关于js的window.open()
window.open是javascript函数,该函数的作用是打开一个新窗口或这改变原来的窗口,不过一般用来的是打开新窗口,因为修改原来的网页地址,可以有另一个函数,那就是window.locati ...
- Android Handler、Message完全解析,带你从源码的角度彻底理解
之前也是由于周末通宵看TI3比赛,一直没找到时间写博客,导致已经有好久没更新了.惭愧!后面还会恢复进度,尽量保证每周都写吧.这里也是先恭喜一下来自瑞典的Alliance战队夺得了TI3的冠军,希望明年 ...
- Visual C# 2010 实现资源管理器
演练:使用设计器创建带有 ListView 和 TreeView 控件的资源管理器样式的界面 Visual Studio 2010 其他版本 此主题尚未评级 - 评价此主题 Vis ...
- python 教程 第十六章、 正则表达式
第十六章. 正则表达式 1) 匹配多个表达式 记号 re1|re2 说明 匹配正则表达式re1或re2 举例 foo|bar 匹配 foo, bar 记号 {N} 说明 匹配前面出 ...
- 微信小程序之商品属性分类
所提及的购物数量的加减,现在说说商品属性值联动选择. 为了让同学们有个直观的了解,到电商网截了一个图片,就是红圈所示的部分 现在就为大家介绍这个小组件,在小程序中,该如何去写 下图为本项目的图: wx ...
- EJB什么,它真的有这么神奇??
1. 我们不禁要问,什么是"服务集群"?什么是"企业发展"? 现在说EJB 至"服务集群"和"企业发展",然后,说什么是 ...
- XDEBUG+PHPSTORM 开发 调试
原文:XDEBUG+PHPSTORM 开发 调试 XDEBUG+PHPSTORM 开发 调试 在我们开发过程中.我们如果经常性的echo.dump效率很低.所以我们就可以使用xdebug进行断点调试. ...
- Android Widget 小工具(两) 使用configure
添加Widget在此之前需要做一些处理操作,可以使用 配置活动 在上一篇的实现基础上,加上配置活动(configure=activity).这时加入Widget时.会先打开一个Activity,进行配 ...
- Swift是一个提供RESTful HTTP接口的对象存储系统,目的是为了提供一个和AWS S3竞争的服务
Swift是一个提供RESTful HTTP接口的对象存储系统,最初起源于Rackspace的Cloud Files,目的是为了提供一个和AWS S3竞争的服务. Swift于2010年开源,是Ope ...