#include<windows.h>#include<cstring>intRunAsAdmin(LPCSTR Path, LPCSTR Param, LPCSTR Dir,int Showcmd){
HINSTANCE res;
res =ShellExecute(NULL,"runas", Path, Param, Dir, Showcmd);return(int)res;}boolIsProcessRunAsAdmin(){
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。


发布评论