网上很对跳过UAC资料都是说如果让UAC弹出窗体,并没有真正跳过弹窗,这里结合动态提权+计划任务实现真正意义上的跳过UAC弹窗,运行程序的时候可以不出现UAC窗体,并且程序还是以高权限运行。

vista及其以后系统多程序的安全进行了控制,经过允许的程序才能执行,但是每次运行程序都弹出UAC控制窗体很烦人,网上看了一些资料,大致归纳出两种方案:

方案一:程序自身具备高权限(win7下带有盾牌图标),通过一个低权限程序调用计划任务来调用程序自身,实现跳过UAC弹窗

方案二:程序自身是普通权限,通过运行时动态提升权限结合计划任务实现跳过UAC弹窗

两种方案都需要通过计划任务来实现,因为几乎任务权限很高,通过高权限的计划任务调用程序,就不会有UAC弹窗提示。

下面以方案二实现来说一下:

首先创建一个普通权限的进程,在进程初始化的时候进行判断,以对话框程序为例。代码如下:

  1. BOOL CSkipUACDemoApp::InitInstance()
  2. {
  3. if (IsEnableUAC() && !IsProcessRunAsAdmin())
  4. {
  5. BOOL bSkipUAC = FALSE;
  6. HINSTANCE hInstance = 0;
  7. if(bSkipUAC )//跳过
  8. {
  9. MessageBox(NULL,_T("跳过UAC"),_T("提示"),MB_OK);
  10. //跳过UAC弹窗关键部分,通过运行计划任务实现跳过UAC弹窗
  11. hInstance = ShellExecute(NULL,_T("open"),_T("schtasks.exe"),_T(" /run /TN \"SkipUAC\""),NULL,SW_HIDE);
  12. }
  13. if (!bSkipUAC || ((int)hInstance <= 32))
  14. {
  15. MessageBox(NULL,_T("进行提权操作"),_T("提示"),MB_OK);
  16. RunElevated(NULL,_T("进程全路径"));
  17. }
  18. return FALSE;
  19. }
  20. MessageBox(NULL,_T("高权限运行程序"),_T("提示"),MB_OK);
  21. //代码省略
  22. .......................................
  23. }

检查是否设置了UAC控制:IsEnableUAC() (忘记参考自哪里了,抱歉)

检查进程是否以高权限运行:IsProcessRunAsAdmin() 参考:http://blog.csdn.net/just_fancy/article/details/6310347

动态提升权限:RunElevated() 参考:http://blog.csdn.net/jehnjehn/article/details/7564548

其中,计划任务需要提前创建,名称SkipUAC,名字可以随便取,只要对应上就行

下面给出其他三个函数代码,网上找到:

  1. BOOL
  2. RunElevated(    HWND hwnd,
  3. LPCTSTR pszPath,
  4. LPCTSTR pszParameters = NULL,
  5. LPCTSTR pszDirectory = NULL )
  6. {
  7. SHELLEXECUTEINFO shex;
  8. memset( &shex, 0, sizeof( shex) );
  9. shex.cbSize        = sizeof( SHELLEXECUTEINFO );
  10. shex.fMask        = 0;
  11. shex.hwnd        = hwnd;
  12. shex.lpVerb        = _T("runas");
  13. shex.lpFile        = pszPath;
  14. shex.lpParameters    = pszParameters;
  15. shex.lpDirectory    = pszDirectory;
  16. shex.nShow        = SW_NORMAL;
  17. return ::ShellExecuteEx( &shex );
  18. }
  19. BOOL  IsProcessRunAsAdmin()
  20. {
  21. SID_IDENTIFIER_AUTHORITY NtAuthority = SECURITY_NT_AUTHORITY;
  22. PSID AdministratorsGroup;
  23. BOOL  bIsAdmin = AllocateAndInitializeSid(
  24. &NtAuthority,
  25. 2,
  26. SECURITY_BUILTIN_DOMAIN_RID,
  27. DOMAIN_ALIAS_RID_ADMINS,
  28. 0, 0, 0, 0, 0, 0,
  29. &AdministratorsGroup);
  30. if (bIsAdmin)
  31. {
  32. CheckTokenMembership(NULL, AdministratorsGroup, &bIsAdmin);
  33. FreeSid(AdministratorsGroup);
  34. }
  35. return  bIsAdmin == TRUE ;
  36. }
  37. BOOL IsEnableUAC(void)
  38. {
  39. BOOL bEnableUAC = FALSE;
  40. OSVERSIONINFO ovi = {0};
  41. ovi.dwOSVersionInfoSize = sizeof(ovi);
  42. if (::GetVersionEx(&ovi))
  43. {
  44. // window vista or windows server 2008 or later operating system
  45. if ( ovi.dwMajorVersion > 5 )
  46. {
  47. HKEY hKey = NULL;
  48. DWORD dwType = REG_DWORD;
  49. DWORD dwEnableLUA = 0;
  50. DWORD dwSize = sizeof(DWORD);
  51. LSTATUS lRet = ::RegOpenKeyEx(HKEY_LOCAL_MACHINE,
  52. _T("SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Policies\\System\\"),
  53. 0, KEY_READ, &hKey);
  54. if( ERROR_SUCCESS == lRet )
  55. {
  56. lRet = ::RegQueryValueEx(hKey, _T("EnableLUA"), NULL, &dwType, (BYTE*)&dwEnableLUA, &dwSize);
  57. ::RegCloseKey(hKey);
  58. if( ERROR_SUCCESS == lRet )
  59. {
  60. bEnableUAC = (dwEnableLUA) ? TRUE : FALSE;
  61. }
  62. }
  63. }
  64. }
  65. return bEnableUAC;
  66. }

这样运行的程序始终都能以高权限运行,并且可以设置是否跳过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研究及实现思路(两种方法,现在可能都不行了)的更多相关文章

  1. 【Qt】实现程序重启的两种方法

    Qt5/PyQt5 实现程序重启的两种方法 前言 最近在写一个开源项目,需要实现一个程序自动重启的功能.尝试了好几种方式,效果均不太理想. 一开始的实现思路是,记为思路一吧.大概就是写一些 shell ...

  2. WPF程序将DLL嵌入到EXE的两种方法

    WPF程序将DLL嵌入到EXE的两种方法 这一篇可以看作是<Visual Studio 版本转换工具WPF版开源了>的续,关于<Visual Studio 版本转换工具WPF版开源了 ...

  3. C#中得到程序当前工作目录和执行目录的五种方法

    string str="";str += "\r\n" + System.Diagnostics.Process.GetCurrentProcess().Mai ...

  4. 在Java Web程序中使用监听器可以通过以下两种方法

    之前学习了很多涉及servlet的内容,本小结我们说一下监听器,说起监听器,编过桌面程序和手机App的都不陌生,常见的套路都是拖一个控件,然后给它绑定一个监听器,即可以对该对象的事件进行监听以便发生响 ...

  5. jquery/js/a标签实现当前页面跳转的两种方法

    在逛购物网站首页时经常看到侧边导航栏,当我们点击导航栏中某一项时会跳转到当前页面的某一处 有两种方法实现,一种是利用js计算好各位置的高度,通过绑定事件使页面跳转到指定位置,另一种是利用a标签进行当前 ...

  6. vue里使用element饿了么的el-menu+vue-router实现路由跳转的两种方法

    最近准备写一个echarts的可视化展示案例,首先用vue-cli3创建了一个项目(好像vue-cli4也出来,感觉变化不大,就没升级了) 然后,开始配置路由↓下面是我的router.js文件 imp ...

  7. 跳转Activity两种方法

    摘要:假设从A界面开启另外一个B界面根据是否需要返回数据分为两种方式 一.无需返回数据方式 在A界面中调用startActivity方法进行直接跳转即可 二.需要返回数据方式 1.在A界面中调用sta ...

  8. 让程序只运行一个实例(Delphi篇)(三种方法,其中使用全局原子的方法比较有意思)

    Windows 下一个典型的特征就是多任务,我们可以同时打开多个窗口进行操作,也可以同时运行程序的多个实例,比如可以打开许多个资源管理器进行文件的移动复制操作.但有时出于某种考虑(比如安全性),我们要 ...

  9. 在linux环境下编译运行OpenCV程序的两种方法

    原来以为在Ubuntu下安装好了OpenCV之后,自己写个简单的程序应该很容易吧,但是呢,就是为了编译一个简单的显示图片的程序我都快被弄崩溃了. 在谷歌和上StackOverFlow查看相关问题解答之 ...

随机推荐

  1. for循环中setTimeout,var与let的不同

    先看下面两段代码 for (let i = 0; i < 5; i++) { setTimeout(function () { console.log(i) }, 2000) } for (va ...

  2. Diffie-Hellman Key Exchange – A Non-Mathematician’s Explanation

    The Complete Diffie-Hellman Key Exchange Diagram The process begins when each side of the communicat ...

  3. 解决无法定位程序输入点SymEnumSymbols于动态链接库dbghelp.dll

    作者:朱金灿 来源:http://blog.csdn.net/clever101 下载一个源码,使用VS2008编译链接无问题,运行时出现一个错误:无法定位程序输入点SymEnumSymbols于动态 ...

  4. 深度学习实践指南(六)—— ReLU(前向和后向过程)

    def relu_forward(x): out = x * (x > 0) # * 对于 np.ndarray 而言表示 handmard 积,x > 0 得到的 0和1 构成的矩阵 r ...

  5. CCLink

    1什么是CC-Link? CC-Link全称Control & Communication Link,即控制与通信链路通信,是一种可以同时高速处理控制和信息数据的现场网络系统,可以提供高效.一 ...

  6. QT之二级菜单(二级菜单的箭头可以使用QSS设置图片)

    QT之二级菜单 QT之二级菜单 开场白 效果图 上代码 可参考文章 下代码 结尾 开场白 今天我们一起来了解下,在我们QT中,二级菜单是如何实现的,在上篇我们学习了QT之系统托盘,QT之自定义菜单,  ...

  7. Java--分布式系统高并发解决方案

    对于我们开发的网站,如果网站的访问量非常大的话,那么我们就需要考虑相关的并发访问问题了.而并发问题是绝大部分的程序员头疼的问题, 但话又说回来了,既然逃避不掉,那我们就坦然面对吧~今天就让我们一起来研 ...

  8. Coverage数据拓扑

    什么是Coverage?   Coverage数据模型源于ESRI公司1981年推出的第一个商业GIS软件——ArcInfo.也被称为地理相关数据模型(Georelational Data Model ...

  9. zcelib - One cplusplus C++ crossplatform library use for develop server,similar to ACE.

    zcelib - One cplusplus C++ crossplatform library use for develop server,similar to ACE.OS适配层,为了适应WIN ...

  10. ThreadPoolExecutor原理和使用

    大家先从ThreadPoolExecutor的整体流程入手: 针对ThreadPoolExecutor代码.我们来看下execute方法: public void execute(Runnable c ...