在Win7中,当应用程序试图改变计算机的设置时会弹出UAC通知;更麻烦的是: 当用户用管理员权限安装此程序后,非管理员帐户无法运行此程序,此时只能选择管理员帐户然输入密码后才能运行,这有点像Ubuntu的sudo。
msdn 里提供了一种改变应用程序当前运行权限的方法,具体如下:
运行VS2005自带的mt.exe工具,向目标应用程序加入manifest资源:
<?xml version='1.0' encoding='UTF-8' standalone='yes'?>
<assembly xmlns='urn:schemas-microsoft-com:asm.v1' manifestVersion='1.0'>
<assemblyIdentity
version='1.0.0.0'
processorArchitecture='X86'
name='your_app_name.exe.manifest'
type='win32'
/>
<trustInfo xmlns='urn:schemas-microsoft-com:asm.v3'>
<security>
<requestedPrivileges>
<requestedExecutionLevel level='asInvoker' uiAccess='false'/>
</requestedPrivileges>
</security>
</trustInfo>
</assembly>
将此段xml保存为 your_app_name.exe.manifest
注:
配置选项requestedExecutionLevel,用于配置当前应用请求的执行权限级别。有3个值可供选择:
asInvoker : 应用程序就是以当前的权限运行;
highestAvailable: 以当前用户可以获得的最高权限运行;
requireAdministrator: 以系统管理员权限运行;
运行命令:
mt.exe -manifest your_app_name.exe.manifest -outputresource:your_app_name.exe;1
可以看到应用程序的图标上盾牌标记已经消失。
参考资料:msdn