当前位置: 首页 > article >正文

AdjustTokenPrivileges启用权限

原文链接地址:http://blog.csdn.net/xbgprogrammer/article/details/7276760

   我们有很多操作需要用到OpenProcess函数,而为了使程序有权限使用这个函数,我们经常利用AdjustTokenPrivileges提升权限(准确的说不是提升,而是将访问令牌中禁用的权限启用)

BOOL SetPrivilege(HANDLE hToken,          // access token handleLPCTSTR lpszPrivilege,  // name of privilege to enable/disableBOOL bEnablePrivilege   // to enable or disable privilege
                  ) 
{TOKEN_PRIVILEGES tp;LUID luid;if ( !LookupPrivilegeValue( NULL,            // lookup privilege on local systemlpszPrivilege,   // privilege to lookup &luid ) )        // receives LUID of privilege
    {printf("LookupPrivilegeValue error: %u\n", GetLastError() ); return FALSE; }tp.PrivilegeCount = 1;tp.Privileges[0].Luid = luid;if (bEnablePrivilege)tp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;elsetp.Privileges[0].Attributes = 0;// Enable the privilege or disable all privileges.if ( !AdjustTokenPrivileges(hToken, FALSE, &tp, sizeof(TOKEN_PRIVILEGES), (PTOKEN_PRIVILEGES) NULL, (PDWORD) NULL) ){ printf("AdjustTokenPrivileges error: %u\n", GetLastError() ); return FALSE; } if (GetLastError() == ERROR_NOT_ALL_ASSIGNED){printf("The token does not have the specified privilege. \n");return FALSE;} return TRUE;
}void main( )
{HANDLE hToken;BOOL bRet = OpenProcessToken(GetCurrentProcess(),TOKEN_ALL_ACCESS,&hToken);SetPrivilege(hToken,SE_DEBUG_NAME,TRUE);
}

这段代码在xp上没有问题,但如果在windows 7 或者vista上,如果程序以标准用户启动,AdjustTokenPrivileges将会调用失败,以管理员省份启动没有问题。

这是因为在Windows 7上,标准用户权限很少,没有Debug权限,更无从谈起启用Debug权限,用户可以以管理员和标准用户两种方式启用控制台,输入命令whoami /ALL

来查看两种权限下权限的不同

0_132997996303BA

0_1329980003JC4d

PS:即使提升调试权限,也不意味着对其它进程调用OpenProcess会成功(例如win7系统下的system和audiodg进程)

 

 

关于TOKEN_PRIVILEGES结构

typedef struct _TOKEN_PRIVILEGES {  DWORD PrivilegeCount;  LUID_AND_ATTRIBUTES Privileges[ANYSIZE_ARRAY];
} TOKEN_PRIVILEGES, *PTOKEN_PRIVILEGES;

截图20160331111859

转载于:https://www.cnblogs.com/wuyuan2011woaini/p/5340357.html

http://www.lryc.cn/news/2416669.html

相关文章:

  • ARP欺骗断网攻击与中间人欺骗攻击详解
  • Blocked by CC firewall
  • GeoServer发布高清电子地图
  • BigPipe 应用:新浪微博
  • Java3D安装(idea版)
  • VBA:VBA常用小代码合集
  • 电脑系统提示找不到ddraw.dll文件如何解决?
  • pcAnywhere在局域网内的使用图解
  • 中文网站人气排行
  • 实验四 存储器实验
  • Linux中安装MySQL以及报错解决(错误:GPG 检查失败)
  • Android应用Preference相关及源码浅析(Preference组件家族篇)
  • vb相关网站
  • 珍藏多年的各类资源网站分享给大家
  • 目录切换命令
  • Android开发技术栈总结,技巧经验分享
  • CVE-2019-1388 UAC提权 (nt authority\system)
  • InlineHook和API HOOK从原理开始,一次性掌握劫持技术
  • 软件体系结构设计|描述与架构风格
  • handleMessage的使用
  • Windows的窗口刷新机制
  • 新建边城变110千伏输变电工程设计
  • 债券代持理解
  • 美国雷曼兄弟公司简介
  • MSDN Library Visual Studio6.0 简体中文版下载及安装
  • 数据库:关于BULK INSERT 学习笔记(2)
  • 软件产品认定需要准备什么
  • 海思3518E开发笔记1.5——flash分区及uboot、kernel、rootfs烧写并部署
  • 【资源】Android Developer网站无法访问问题的解决之道
  • 网页游戏开发教程