admin 管理员组文章数量: 1184232
#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。
版权声明:本文标题:从零开始:C++中获取系统管理权的步骤解析 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.roclinux.cn/b/1771950530a3550419.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论