我们知道,在Windows Vista ,微软系列操作系统中加入了“UAC”权限控制。这是一个显著的安全性能的提升。
在这以后的系统中软件默认使用普通用户方式运行,除非软件声明要求使用管理员方式运行,或者用户强制使用管理员方式运行。
那么我们在做一些敏感功能的时候,比如结束进程、读写内存、更改系统文件、更改系统设置等操作的时候,就需要提供管理员权限,否则无法获取对象。这时就需要我们手动的,显式的声明程序需要管理员权限运行。那么,我们又如何做到呢?
这里引用微软MSDN的说法:
右键你的工程,新建一个mainfest(应用程序清单)文件,
<!-- UAC 清单选项
如果要更改 Windows 用户帐户控制级别,请用以下节点之一替换
requestedExecutionLevel 节点。
<requestedExecutionLevel level="asInvoker" uiAccess="false" />
<requestedExecutionLevel level="requireAdministrator" uiAccess="false" />
<requestedExecutionLevel level="highestAvailable" uiAccess="false" />
指定 requestedExecutionLevel 节点将会禁用文件和注册表虚拟化。
如果要利用文件和注册表虚拟化实现向后
兼容性,则删除 requestedExecutionLevel 节点。
-->
将 <requestedExecutionLevel level="asInvoker" uiAccess="false" />设置为requireAdministrator后,保存运行。当程序需要管理员权限时,就会提示用户是否允许。
这个是一种方法,还有另外一个方法,是我经常用的。这个需要写在Program.cs里面。
1: static void Main(string[] Args)
2: {
3: /**
4: * 当前用户是管理员的时候,直接启动应用程序
5: * 如果不是管理员,则使用启动对象启动程序,以确保使用管理员身份运行
6: */
7: //获得当前登录的Windows用户标示
8: System.Security.Principal.WindowsIdentity identity = System.Security.Principal.WindowsIdentity.GetCurrent();
9: //创建Windows用户主题
10: Application.EnableVisualStyles();
11:
12: System.Security.Principal.WindowsPrincipal principal = new System.Security.Principal.WindowsPrincipal(identity);
13: //判断当前登录用户是否为管理员
14: if (principal.IsInRole(System.Security.Principal.WindowsBuiltInRole.Administrator))
15: {
16: //如果是管理员,则直接运行
17:
18: Application.EnableVisualStyles();
19: Application.Run(new Form1());
20: }
21: else
22: {
23: //创建启动对象
24: System.Diagnostics.ProcessStartInfo startInfo = new System.Diagnostics.ProcessStartInfo();
25: //设置运行文件
26: startInfo.FileName = System.Windows.Forms.Application.ExecutablePath;
27: //设置启动参数
28: startInfo.Arguments = String.Join(" ", Args);
29: //设置启动动作,确保以管理员身份运行
30: startInfo.Verb = "runas";
31: //如果不是管理员,则启动UAC
32: System.Diagnostics.Process.Start(startInfo);
33: //退出
34: System.Windows.Forms.Application.Exit();
35: }
36: }
本文转自 OH51888 51CTO博客,原文链接:http://blog.51cto.com/rozbo/1298086,如需转载请自行联系原作者