程序跳过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查看相关问题解答之 ...
随机推荐
- ajax——XMLHttpRequest
XMLHttpRequest对象.能够让ajax程序在不又一次载入的页面的情况下更新页面数据,页面载入完毕后从server接受发生数据.这样既减轻了server负担又回顾了响应速度,缩短了用户的等待时 ...
- 【Cocos2d-x Lua】数据库封装类型的操作
Lua数据库封装类型的操作 使用演示样例 lua代码: require("DB") -- 保存一个字符串(数据库中存储的数据都是以字符串的形式保存的) DB:getInstance ...
- uml 类图依赖与关联的区别
类与类之间由弱到强关系是: 没关系 < 依赖 < 关联 < 聚合 < 组合. 1.依赖(dependency) 可以简单的理解,就是一个类A使用到了另一个类B,而这种使用 ...
- 发布与订阅SQLServer
SQLServer 中发布与订阅 在对数据库做迁移的时候,会有很多方法,用存储过程,job,也可以用开源工具lettle,那么今天这些天变接触到了一种新的方法,就是SqlServer中自带的发布与订阅 ...
- 高科技 stuff
热成像摄像机 收集特定频率的电磁波: 蓝色:温度较低:红色:温度较高
- Cocos2d-X中国象棋的发展《五岁以下儿童》摆棋
在博客上,以实现创建的游戏场景.而一些button,因为button落实到事件作出详细答复,需要使用一些功能摆棋.为此我特意button上的背面的具体实施, 在摆棋前先理清一下摆棋的思路: 1.创建一 ...
- 机器学习编程接口(api)设计(oop 设计)
fit: 对于 kmeans 来说,fit 的过程,就是训练,自然所需的参数,主要是数据集和聚类中心数, 1. classification(分类) def train(train_images, t ...
- CentOS6.5系统挂载NTFS分区的移动硬盘
CentOS6.5系统挂载NTFS分区的移动硬盘 作为IT的工作者,避免不了使用Linux系统,我如今使用的系统是CentOS6.5 X86_64位版本号,可是插入NTFS移动硬盘没有办法识别.通过以 ...
- 各种工具的使用 tricks
1. 搜狗搜索引擎 因为搜狗与腾讯的合作关系,搜狗搜索引擎提供了"微信"的搜索选项,可直接定位到相关文章,或者公众号. weixin.sougou.com 2. PyCharm P ...
- Qt5.4.1在windows7配置Android开发环境(阳光柠檬_)
网上的说法有些时间比较久远,软件更新又快,配置路上总有一些坎坷. 自己亲自尝试了一遍,记录下来. 所需的软件: 1. qt-opensource-windows-x86-android-5.4.1.e ...