管理员权限提权功能
//***************************************************
// 函数名称: EnableDebugPrivilege
// 函数说明: 管理员权限提权
// 方 式:public
// 输入参数: void
// 输出参数:void
// 返 回 值: true-提权成功,false-提权失败
// 作 者:
// 创建时间: 2018-11-5
// 备 注:
//***************************************************
bool EnableDebugPrivilege()
{
HANDLE hToken;
LUID sedebugnameValue;
TOKEN_PRIVILEGES tkp;
if (!OpenProcessToken(GetCurrentProcess(), TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY, &hToken)) {
return false;
}
if (!LookupPrivilegeValue(NULL, SE_DEBUG_NAME, &sedebugnameValue)) {
__try {
if (hToken) {
CloseHandle(hToken);
}
} __except(EXCEPTION_EXECUTE_HANDLER) {};
return false;
}
tkp.PrivilegeCount = 1;
tkp.Privileges[0].Luid = sedebugnameValue;
tkp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
if (!AdjustTokenPrivileges(hToken, FALSE, &tkp, sizeof(tkp), NULL, NULL)) {
__try {
if(hToken) {
CloseHandle(hToken);
}
} __except(EXCEPTION_EXECUTE_HANDLER) {};
return false;
}
return true;
}