首先,为什么要以管理员权限打开应用程序呢?
管理员拥有计算机管理的最高权限,以管理员身份可以执行任何操作,而普通用户则有很大限制,比如非管理员不能修改注册表,不能自己安装软件等等。
这次做了个配置固定ip的桌面应用程序,功能和师兄的固定ip批处理文件作用一样。师兄的批处理文件需要以管理员身份运行,所以我做同样也需要。在c#中怎么做呢?有三个办法。
一、在项目属性里添加app.manifest(应用程序清单文件)
1.打开项目的属性
2.选择“安全性”,勾选“启用ClickOnce安全设置”
3.然后会在Properties里自动生成 app.manifest
4.打开app.manifest,找到图中箭头指向位置,修改为level=“requireAdministrator”(如图注释所述,用户账户控制级别有asInvoker(当前调用者,以当前权限运行),requireAdministrator(要求管理员权限),highestAvailable(当前用户可以获得的最高权限))
5.如果现在直接运行会报错:
所以要在之前的属性里取消勾选“启用ClickOnce安全设置”。
现在运行程序就会要求以管理员身份运行了。
在vs里:
另外,在以管理员身份运行的vs里对其他程序的调用也会以管理员身份,因为程序的默认用户账户控制是asInvoker(以当前调用权限运行)。
二、直接在项目里添加“应用程序清单”这个类
对app.manifest的相应修改同第一个办法。
三、在App.xaml.cs里通过System.Diagnostics.Process.Start()方式启动程序
打开App.xaml.cs,编辑代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
|
using
System;
using
System.Reflection;
using
System.Security.Principal;
using
System.Windows;
namespace
管理员运行
{
/// <summary>
/// App.xaml 的交互逻辑
/// </summary>
public
partial
class
App : Application
{
public
App()
{
/**
* 当前用户是管理员的时候,直接启动应用程序
* 如果不是管理员,则使用启动对象启动程序,以确保使用管理员身份运行
*/
//获得当前登录的Windows用户标示
WindowsIdentity identity = WindowsIdentity.GetCurrent();
WindowsPrincipal principal =
new
WindowsPrincipal(identity);
//判断当前登录用户是否为管理员
if
(principal.IsInRole(WindowsBuiltInRole.Administrator))
{
//如果是管理员,则直接运行
Run(
new
MainWindow());
}
else
{
//创建启动对象
System.Diagnostics.ProcessStartInfo startInfo =
new
System.Diagnostics.ProcessStartInfo();
startInfo.UseShellExecute =
true
;
startInfo.WorkingDirectory = Environment.CurrentDirectory;
startInfo.FileName = Assembly.GetExecutingAssembly().Location;
//设置启动动作,确保以管理员身份运行
startInfo.Verb =
"runas"
;
try
{
System.Diagnostics.Process.Start(startInfo);
}
catch
{
return
;
}
//退出
Application.Current.Shutdown();
}
}
}
}
|