C# 查询一个进程是否有管理员权限

        var hasElevated = false;
        var processName = Process.GetCurrentProcess().ProcessName;
        Process[] processes = Process.GetProcessesByName(processName);
        foreach (var process in processes)
        {
            Console.WriteLine($"进程名称: {process.ProcessName}");
            hasElevated = ProcessHasElevatedPrivileges(process);
            Console.WriteLine($"特权: {hasElevated}");
            if (hasElevated) break;
        }

static bool ProcessHasElevatedPrivileges(Process process)
{
    if (Environment.OSVersion.Version.Major >= 6)
    {
        IntPtr hObject = process.Handle;
        return IsProcessElevated(hObject);
    }
    return false;
}

static bool IsProcessElevated(IntPtr hProcess)
{
    if (!NativeMethods.OpenProcessToken(hProcess, 0x20 | 0x0008, out IntPtr hToken))
    {
        throw new System.ComponentModel.Win32Exception();
    }

    var elevation = default(NativeMethods.TOKEN_ELEVATION);  // 初始化 elevation
    try
    {
        if (!NativeMethods.GetTokenInformation(hToken, NativeMethods.TOKEN_INFORMATION_CLASS.TokenElevation, ref elevation, Marshal.SizeOf(typeof(NativeMethods.TOKEN_ELEVATION)), out var returnLength))
        {
            throw new System.ComponentModel.Win32Exception();
        }

        return elevation.TokenIsElevated != 0;
    }
    finally
    {
        NativeMethods.CloseHandle(hToken);
    }
}

internal static class NativeMethods
{
    [DllImport("kernel32.dll", SetLastError = true)]
    [return: MarshalAs(UnmanagedType.Bool)]
    public static extern bool CloseHandle(IntPtr hObject);

    [DllImport("kernel32.dll", SetLastError = true)]
    public static extern bool OpenProcessToken(IntPtr processHandle, uint desiredAccess, out IntPtr tokenHandle);

    [DllImport("advapi32.dll", SetLastError = true)]
    public static extern bool GetTokenInformation(IntPtr tokenHandle, TOKEN_INFORMATION_CLASS tokenInformationClass, ref TOKEN_ELEVATION TokenInformation, int tokenInformationLength, out int returnLength);

    public enum TOKEN_INFORMATION_CLASS
    {
        TokenElevation = 20,
        TokenElevationType
    }

    [StructLayout(LayoutKind.Sequential)]
    public struct TOKEN_ELEVATION
    {
        public int TokenIsElevated;
    }
}
  • 9
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C#中,要以管理员权限读写文件,可以使用以下代码片段: ``` using System; using System.Security.Principal; public static bool HasAdminRights() { WindowsIdentity identity = WindowsIdentity.GetCurrent(); WindowsPrincipal principal = new WindowsPrincipal(identity); return principal.IsInRole(WindowsBuiltInRole.Administrator); } public static void WriteToFile(string filePath, string content) { if (HasAdminRights()) { // 以管理员权限直接写入文件 System.IO.File.WriteAllText(filePath, content); } else { // 创建一个管理员权限运行进程 System.Diagnostics.ProcessStartInfo startInfo = new System.Diagnostics.ProcessStartInfo(); startInfo.FileName = System.Windows.Forms.Application.ExecutablePath; startInfo.Arguments = $"\"{filePath}\" \"{content}\""; startInfo.Verb = "runas"; System.Diagnostics.Process.Start(startInfo); } } public static string ReadFromFile(string filePath) { if (HasAdminRights()) { // 以管理员权限直接读取文件内容 return System.IO.File.ReadAllText(filePath); } else { // 创建一个管理员权限运行进程 System.Diagnostics.ProcessStartInfo startInfo = new System.Diagnostics.ProcessStartInfo(); startInfo.FileName = System.Windows.Forms.Application.ExecutablePath; startInfo.Arguments = $"\"{filePath}\""; startInfo.Verb = "runas"; System.Diagnostics.Process.Start(startInfo); // 等待进程完成后再读取文件内容 System.Threading.Thread.Sleep(2000); return System.IO.File.Exists(filePath) ? System.IO.File.ReadAllText(filePath) : null; } } ``` 使用上述代码,你可以调用`WriteToFile`方法以管理员权限写入文件,调用`ReadFromFile`方法以管理员权限读取文件内容。如果当前用户已经具有管理员权限,则直接进行文件操作;否则,会弹出UAC提示框,用户需要选择以管理员身份运行程序,然后在程序中进行文件操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值