#include <windows.h>
#include <cstring>
int RunAsAdmin(LPCSTR Path, LPCSTR Param, LPCSTR Dir, int Showcmd)
{
HINSTANCE res;
res = ShellExecute(NULL, "runas", Path, Param, Dir, Showcmd);
return (int)res;
}
bool IsProcessRunAsAdmin()
{
SID_IDENTIFIER_AUTHORITY NtAuthority = SECURITY_NT_AUTHORITY;
PSID AdministratorsGroup;
BOOL b = AllocateAndInitializeSid(
&NtAuthority,
2,
SECURITY_BUILTIN_DOMAIN_RID,
DOMAIN_ALIAS_RID_ADMINS,
0, 0, 0, 0, 0, 0,
&AdministratorsGroup);
if(b)
{
CheckTokenMembership(NULL, AdministratorsGroup, &b);
FreeSid(AdministratorsGroup);
}
return b == TRUE;
}
使用时调用GetAdmin,一个参数是程序运行时的参数,另一个是启动窗口的状态。这个函数会先判断程序是否有管理员权限,如果没有就尝试获取,获取成功就会返回1(表示又启动了一个有管理员权限的程序,并非当前程序获得了管理员权限,这个不可能做到),获取失败返回0,本来已有管理员权限则返回2。
原文链接
该博客介绍了如何在Windows环境中检查和获取程序的管理员权限。通过RunAsAdmin函数,可以尝试以管理员权限重新启动程序,而IsProcessRunAsAdmin函数用于检查当前进程是否已经具备管理员权限。这两个函数对于需要管理员权限才能执行操作的软件开发至关重要。

1万+

被折叠的 条评论
为什么被折叠?



