C++升降权限的原理与实践

本文详细探讨了C++在Windows环境下如何进行权限升降,包括SYSTEM管理员进程创建USER普通和管理员权限进程,以及USER权限进程之间的权限转换。文章介绍了相关Windows权限概念,如Session和用户权限类型,并提供了具体的API调用示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

C++升降权限的原理与实践

本文主要介绍几种C++程序内部进行权限升降的方法,为以后开发过程中可能会遇到的操作系统权限相关问题提供参考意见。

Windows权限基本概念

Windows权限
用户账户控制

Windows程序可能拥有的权限

简单来说,Windows环境下的程序运行时所拥有的权限有以下四种:

  • 用户管理员权限
  • 用户普通权限
  • 系统管理员权限
  • 系统普通权限(很少有程序拥有该权限)

Windows session介绍

在Windows XP、Windows Server 2003 或早期Windows 系统时代,当第一个用户登录系统后服务和应用程序是在同一个Session 中运行的。但是这种运行方式提高了系统安全风险,因为服务是通过提升了用户权限运行的,而应用程序往往是那些不具备管理员身份的普通用户运行的。
从Vista 开始Session 0 中只包含系统服务,其他应用程序则通过分离的Session 运行,将服务与应用程序隔离提高系统的安全性。这样使得Session 0 与其他Session 之间无法进行交互,不能通过服务向桌面用户弹出信息窗口、UI 窗口等信息。如下图所示:
avatar

C++程序内的权限升降

SYSTEM管理员进程创建USER普通权限进程

基于上述相关内容,Windows服务程序与其他程序运行于不同session,所以要使拥有系统管理员权限的程序创建拥有用户普通权限的进程,需要以下三步:

  1. 获取当前用户所在的sessionId
    获取当前登录用户所在的sessionId有多种方法,由于很多时候,每台电脑都会只创建一个用户,所以sessionId直接取“1”即可,当然,这种方式并不严谨,所以需要通过Windo
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值