程序跳过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查看相关问题解答之 ...
随机推荐
- 通过一次SpringBoot打成war包部署到tomcat启动总结一般jar包冲突的解决方法
启动时,报错信息如下: 28-Sep-2018 16:55:41.567 严重 [localhost-startStop-1] org.apache.catalina.core.StandardCon ...
- Qt 元对象系统(Meta-Object System)(不管是否使用信号槽,都推荐使用)
Qt 元对象系统(Meta-Object System) Qt的元对象系统基于如下三件事情: 类:QObject,为所有需要利用原对象系统的对象提供了一个基类. 宏:Q_OBJECT,通常可以声明在类 ...
- 为什么唱iOS 6.0选择Mantle
近来的mt=8" target="_blank" rel="external">iOS的6.0版本号已经成功上线了. 18人月的投入,2500个 ...
- WPF 获得触摸精度和触摸点
原文:WPF 获得触摸精度和触摸点 本文主要告诉大家如何获得所有的触摸设备的触摸精度和触摸点数. 需要通过反射的方法才可以拿到触摸的精度. 使用 Tablet.TabletDevices 可以获得所有 ...
- TableLayout表格布局
1.本节学习路线图 路线图分析: 从上面的路线图,可以看出TableLayout的用法还是很简单的,无非就是确定表格的行数,以及使用 那三个属性来设置每一行中的第某列的元素隐藏,拉伸,或者收缩即可! ...
- Troubleshooting routing topology based on a reference topology
In one embodiment, a computing device (e.g., border router or network management server) transmits a ...
- 在JScript中使用正则表达式
作者:朱金灿 来源:http://blog.csdn.net/clever101 不废话了,直接用代码说明吧: main(); function main() { try { // 运用正则表达式进行 ...
- CUDA+OpenCV 绘制朱利亚(Julia)集合图形
Julia集中的元素都是经过简单的迭代计算得到的,很适合用CUDA进行加速.对一个600*600的图像,需要进行360000次迭代计算,所以在CUDA中创建了600*600个线程块(block),每个 ...
- QComboBox实现复选功能(三种方法:嵌套QListWidget, 设置QStandardItemModel, 设置Delegate)
今天介绍一下一个小东西 — 如何让QComboBox实现复选功能? 需求: 下拉列表有复选功能 不可编辑 显示所有选中项 关于QComboBox的复选功能有几种方案: QStandardIte ...
- WPF 判断值是不是NaN
原文:WPF 判断值是不是NaN 经常要在StoryBoard用到的 判断方法: Double.IsNaN(你要判断的值)= true// NaN 否则就不是.