程序跳过UAC研究及实现思路(两种方法,现在可能都不行了)
网上很对跳过UAC资料都是说如果让UAC弹出窗体,并没有真正跳过弹窗,这里结合动态提权+计划任务实现真正意义上的跳过UAC弹窗,运行程序的时候可以不出现UAC窗体,并且程序还是以高权限运行。
vista及其以后系统多程序的安全进行了控制,经过允许的程序才能执行,但是每次运行程序都弹出UAC控制窗体很烦人,网上看了一些资料,大致归纳出两种方案:
方案一:程序自身具备高权限(win7下带有盾牌图标),通过一个低权限程序调用计划任务来调用程序自身,实现跳过UAC弹窗
方案二:程序自身是普通权限,通过运行时动态提升权限结合计划任务实现跳过UAC弹窗
两种方案都需要通过计划任务来实现,因为几乎任务权限很高,通过高权限的计划任务调用程序,就不会有UAC弹窗提示。
下面以方案二实现来说一下:
首先创建一个普通权限的进程,在进程初始化的时候进行判断,以对话框程序为例。代码如下:
- BOOL CSkipUACDemoApp::InitInstance()
- {
- if (IsEnableUAC() && !IsProcessRunAsAdmin())
- {
- BOOL bSkipUAC = FALSE;
- HINSTANCE hInstance = 0;
- if(bSkipUAC )//跳过
- {
- MessageBox(NULL,_T("跳过UAC"),_T("提示"),MB_OK);
- //跳过UAC弹窗关键部分,通过运行计划任务实现跳过UAC弹窗
- hInstance = ShellExecute(NULL,_T("open"),_T("schtasks.exe"),_T(" /run /TN \"SkipUAC\""),NULL,SW_HIDE);
- }
- if (!bSkipUAC || ((int)hInstance <= 32))
- {
- MessageBox(NULL,_T("进行提权操作"),_T("提示"),MB_OK);
- RunElevated(NULL,_T("进程全路径"));
- }
- return FALSE;
- }
- MessageBox(NULL,_T("高权限运行程序"),_T("提示"),MB_OK);
- //代码省略
- .......................................
- }
检查是否设置了UAC控制:IsEnableUAC() (忘记参考自哪里了,抱歉)
检查进程是否以高权限运行:IsProcessRunAsAdmin() 参考:http://blog.csdn.net/just_fancy/article/details/6310347
动态提升权限:RunElevated() 参考:http://blog.csdn.net/jehnjehn/article/details/7564548
其中,计划任务需要提前创建,名称SkipUAC,名字可以随便取,只要对应上就行
下面给出其他三个函数代码,网上找到:
- BOOL
- RunElevated( HWND hwnd,
- LPCTSTR pszPath,
- LPCTSTR pszParameters = NULL,
- LPCTSTR pszDirectory = NULL )
- {
- SHELLEXECUTEINFO shex;
- memset( &shex, 0, sizeof( shex) );
- shex.cbSize = sizeof( SHELLEXECUTEINFO );
- shex.fMask = 0;
- shex.hwnd = hwnd;
- shex.lpVerb = _T("runas");
- shex.lpFile = pszPath;
- shex.lpParameters = pszParameters;
- shex.lpDirectory = pszDirectory;
- shex.nShow = SW_NORMAL;
- return ::ShellExecuteEx( &shex );
- }
- BOOL IsProcessRunAsAdmin()
- {
- SID_IDENTIFIER_AUTHORITY NtAuthority = SECURITY_NT_AUTHORITY;
- PSID AdministratorsGroup;
- BOOL bIsAdmin = AllocateAndInitializeSid(
- &NtAuthority,
- 2,
- SECURITY_BUILTIN_DOMAIN_RID,
- DOMAIN_ALIAS_RID_ADMINS,
- 0, 0, 0, 0, 0, 0,
- &AdministratorsGroup);
- if (bIsAdmin)
- {
- CheckTokenMembership(NULL, AdministratorsGroup, &bIsAdmin);
- FreeSid(AdministratorsGroup);
- }
- return bIsAdmin == TRUE ;
- }
- BOOL IsEnableUAC(void)
- {
- BOOL bEnableUAC = FALSE;
- OSVERSIONINFO ovi = {0};
- ovi.dwOSVersionInfoSize = sizeof(ovi);
- if (::GetVersionEx(&ovi))
- {
- // window vista or windows server 2008 or later operating system
- if ( ovi.dwMajorVersion > 5 )
- {
- HKEY hKey = NULL;
- DWORD dwType = REG_DWORD;
- DWORD dwEnableLUA = 0;
- DWORD dwSize = sizeof(DWORD);
- LSTATUS lRet = ::RegOpenKeyEx(HKEY_LOCAL_MACHINE,
- _T("SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Policies\\System\\"),
- 0, KEY_READ, &hKey);
- if( ERROR_SUCCESS == lRet )
- {
- lRet = ::RegQueryValueEx(hKey, _T("EnableLUA"), NULL, &dwType, (BYTE*)&dwEnableLUA, &dwSize);
- ::RegCloseKey(hKey);
- if( ERROR_SUCCESS == lRet )
- {
- bEnableUAC = (dwEnableLUA) ? TRUE : FALSE;
- }
- }
- }
- }
- return bEnableUAC;
- }
这样运行的程序始终都能以高权限运行,并且可以设置是否跳过UAC弹窗。
演示程序源码下载:http://download.csdn.net/detail/daiafei/6771671
(win7可以 win8.1不行)
由于在win7下,使用ITask接口无法控制计划任务创建多个实例的进程,另外写了个演示程序,演示程序及源码下载:http://download.csdn.net/detail/daiafei/6814109
界面中的复选框勾选的时候会检查计划任务是否需要创建及是否创建成功,取消创建会删除计划任务。
http://blog.csdn.net/daiafei/article/details/17578723
程序跳过UAC研究及实现思路(两种方法,现在可能都不行了)的更多相关文章
- 【Qt】实现程序重启的两种方法
Qt5/PyQt5 实现程序重启的两种方法 前言 最近在写一个开源项目,需要实现一个程序自动重启的功能.尝试了好几种方式,效果均不太理想. 一开始的实现思路是,记为思路一吧.大概就是写一些 shell ...
- WPF程序将DLL嵌入到EXE的两种方法
WPF程序将DLL嵌入到EXE的两种方法 这一篇可以看作是<Visual Studio 版本转换工具WPF版开源了>的续,关于<Visual Studio 版本转换工具WPF版开源了 ...
- C#中得到程序当前工作目录和执行目录的五种方法
string str="";str += "\r\n" + System.Diagnostics.Process.GetCurrentProcess().Mai ...
- 在Java Web程序中使用监听器可以通过以下两种方法
之前学习了很多涉及servlet的内容,本小结我们说一下监听器,说起监听器,编过桌面程序和手机App的都不陌生,常见的套路都是拖一个控件,然后给它绑定一个监听器,即可以对该对象的事件进行监听以便发生响 ...
- jquery/js/a标签实现当前页面跳转的两种方法
在逛购物网站首页时经常看到侧边导航栏,当我们点击导航栏中某一项时会跳转到当前页面的某一处 有两种方法实现,一种是利用js计算好各位置的高度,通过绑定事件使页面跳转到指定位置,另一种是利用a标签进行当前 ...
- vue里使用element饿了么的el-menu+vue-router实现路由跳转的两种方法
最近准备写一个echarts的可视化展示案例,首先用vue-cli3创建了一个项目(好像vue-cli4也出来,感觉变化不大,就没升级了) 然后,开始配置路由↓下面是我的router.js文件 imp ...
- 跳转Activity两种方法
摘要:假设从A界面开启另外一个B界面根据是否需要返回数据分为两种方式 一.无需返回数据方式 在A界面中调用startActivity方法进行直接跳转即可 二.需要返回数据方式 1.在A界面中调用sta ...
- 让程序只运行一个实例(Delphi篇)(三种方法,其中使用全局原子的方法比较有意思)
Windows 下一个典型的特征就是多任务,我们可以同时打开多个窗口进行操作,也可以同时运行程序的多个实例,比如可以打开许多个资源管理器进行文件的移动复制操作.但有时出于某种考虑(比如安全性),我们要 ...
- 在linux环境下编译运行OpenCV程序的两种方法
原来以为在Ubuntu下安装好了OpenCV之后,自己写个简单的程序应该很容易吧,但是呢,就是为了编译一个简单的显示图片的程序我都快被弄崩溃了. 在谷歌和上StackOverFlow查看相关问题解答之 ...
随机推荐
- ElasticSearch:分析器
ElasticSearch入门 第七篇:分析器 这是ElasticSearch 2.4 版本系列的第七篇: ElasticSearch入门 第一篇:Windows下安装ElasticSearch El ...
- TensorFlow 学习(四)—— computation graph
TensorFlow 的计算需要事先定义一个 computation graph(计算图),该图是一个抽象的结构,只有在评估(evaluate)时,才有数值解,这点和 numpy 不同.这张图由一组节 ...
- 容易遗忘的JS知识点整理—hasOwnProperty相关
为了判断一个对象是否包含自定义属性而不是原型链上的属性,我们需要使用继承自 Object.prototype 的 hasOwnProperty方法.hasOwnProperty 是 JavaScrip ...
- Cordova app 检查更新 ----JS进行调用(二)
原文:Cordova app 检查更新 ----JS进行调用(二) 1.获取版本号 需要添加 插件 cordova plugin add https://github.com/whiteoctober ...
- 美国是一个"愚蠢而落后的国度"--大家千万别去
看到一篇文章,写的很诙谐风趣,已经被转载无数遍但却不知道原出处.读过之后又值得我们深思.和大家一起分享: 来美国已多时了.我后悔当初的选择.一直都被西方媒体所蒙蔽欺骗,让我错误地以为美国是一个现代化国 ...
- 【24.63%】【codefroces 686D】Kay and Snowflake
time limit per test 3 seconds memory limit per test 256 megabytes input standard input output standa ...
- Creating Apps With Material Design —— Defining Custom Animations
转载请注明 http://blog.csdn.net/eclipsexys 翻译自Developer Android,时间仓促,有翻译问题请留言指出.谢谢 定义动画 在材料设计动画让用户与您的应用程序 ...
- .NET开发人员的瓶颈和职业发展
现在社会比前几年浮躁了,越来越多的人抱怨薪水低,高薪工作不好找; 诚然这有CPI的压力,可是也有很多人没有认清自己的职业发展. 很多.net程序员个各种纠结,想拿高薪又拿不到,想提高又不知道怎么能提高 ...
- Android 项目框架功能整理记录
用来记录自己在项目用到的框架工具等,新人新记录,希望能对你搭建项目有所帮助 常用框架整理 视图绑定注解框架: butterKnife 网络请求框架: OKHttp 图片加载缓存:Gilde 数据格式解 ...
- WPF 控制程序只能启动一次
原文:WPF 控制程序只能启动一次 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/jsyhello/article/details/7411898 ...