进程令牌:Windows 安全架构中的关键元素
一、进程令牌概述
进程令牌(Process Token)是 Windows 操作系统中一个重要的安全机制,它包含了与进程安全上下文相关的详细信息。每个进程在执行时都会关联一个进程令牌,令牌用于确定该进程可以访问哪些资源以及能执行哪些操作。通过对进程令牌的管理,操作系统确保了对系统资源的访问控制,并且可以精确地指定哪些用户或进程可以进行哪些操作。
进程令牌不仅仅是标识用户身份的工具,它还直接影响着进程权限、访问控制及安全操作,进而决定了系统的安全性。
二、进程令牌的组成
进程令牌由多个组成部分构成,下面是令牌的主要内容:
1. 用户 SID(Security Identifier)
用户 SID 是标识进程所属用户或用户组的唯一标识符。每个用户或组在 Windows 系统中都有一个对应的 SID,进程令牌通过该 SID 确定进程的所有者身份。用户 SID 通常与登录到系统的账户相对应,决定了进程属于哪个用户。
2. 组 SID
组 SID 标识了进程所属的用户组。用户组是用于集中管理一组具有相同权限的用户账户。进程令牌中包含组 SID 信息,使得进程不仅仅可以继承用户的权限,也能够继承所属组的权限,进一步控制其访问资源的能力。
3. 权限
权限在进程令牌中定义了进程可以执行的操作类型,如读取、写入、执行等。操作系统根据这些权限来判断进程是否可以访问特定的资源或执行特定的操作。每个进程的令牌都绑定了一个权限集,用以决定它对系统资源的可访问性。
4. 特权
特权是一组更高权限的操作,通常用于系统级别的任务,如修改系统时间、关闭系统等。特权可以在令牌中进行配置,并且只有具备相应特权的进程才能执行这些关键操作。特权的控制通常用于确保系统的核心操作不会被恶意进程或不受信任的用户执行。
5. 令牌类型
令牌类型标识了令牌的作用。主要有两种令牌类型:主令牌(Primary Token)和模拟令牌(Impersonation Token)。
6. 令牌来源
令牌来源指明了令牌是如何产生的。例如,令牌可以来自用户登录过程(如登录令牌),也可以由服务账户生成(如服务令牌)。通过源信息,可以确定令牌是否与某个特定进程或操作相关。
三、进程令牌的类型
Windows 系统支持两种主要的进程令牌类型:主令牌和模拟令牌。
1. 主令牌(Primary Token)
每个进程都拥有一个主令牌,它代表了启动该进程的用户账户的安全上下文。主令牌包含了启动该进程的用户或用户组的 SID,以及相关权限、特权和组 SID 信息。主令牌通常是由操作系统自动为每个新进程创建,并用于控制该进程的访问权限。
2. 模拟令牌(Impersonation Token)
模拟令牌允许一个进程模拟另一个用户的安全上下文。模拟令牌通常用于客户端/服务器应用程序场景中,服务器端进程可以通过模拟客户端的身份来访问系统资源。模拟令牌使得服务器能够代表客户端访问资源,从而实现更为精细的权限控制。
四、进程令牌的使用
进程令牌的主要功能是控制进程对资源的访问权限和操作权限。在 Windows 中,操作系统使用进程令牌来决定进程是否能够执行某项特定操作或访问特定资源。具体来说,进程令牌在以下几方面发挥作用:
1. 访问控制
Windows 使用进程令牌来控制进程的访问权限。进程令牌中的权限和特权决定了该进程可以对哪些资源执行操作。例如,进程令牌可能包括“读取”权限,允许该进程读取文件内容;或者包括“写入”权限,允许进程修改文件。
2. 权限提升
在某些情况下,进程可能需要执行某些高权限操作,例如修改系统设置或安装软件。这时,可以通过修改进程的令牌来提升权限。这一过程通常通过修改进程令牌中的特权字段来完成。权限提升通常是通过调用如 DuplicateTokenEx
等 API 来实现的。
五、基于用户类型的令牌分类
根据不同的用户类型和用途,系统会创建不同类型的令牌,以决定进程或服务能够执行哪些操作。
1. 用户令牌(User Token)
用户令牌是与特定用户账户关联的令牌。它包含了用户的身份信息、组信息和权限,决定了用户能够访问的资源和执行的操作。当用户登录系统时,操作系统为该用户生成一个令牌,用于标识和验证用户的权限。
- 示例:用户登录时,操作系统为其创建一个用户令牌,允许用户访问其权限范围内的文件、目录和系统资源。
2. 管理员令牌(Administrator Token)
管理员令牌通常与具有管理员权限的用户关联。管理员用户拥有更高的系统权限,可以执行修改系统设置、安装软件等操作。对于启用 用户账户控制(UAC) 的系统,管理员用户在大多数情况下会使用标准用户令牌,只有在需要提升权限时,才会使用管理员令牌。
- 示例:当管理员账户执行需要高权限的操作时,系统会提示用户通过 UAC 提升权限,切换到管理员令牌。
3. 服务账户令牌(Service Account Token)
服务账户令牌与特定的服务账户关联,通常用于运行系统服务或应用程序。服务账户拥有与其职责相匹配的权限集,用于控制服务对系统资源的访问。常见的服务账户包括 LocalSystem
、NetworkService
和自定义服务账户。
- 示例:Windows 服务(如 SQL Server)通常以特定的服务账户运行,每个服务账户都有一个独立的令牌,决定了服务能访问哪些资源。
4. 系统令牌(System Token)
系统令牌与操作系统进程相关联,代表了操作系统本身或系统级别的进程。系统令牌具有非常高的权限,通常用于控制对系统级别资源的访问。操作系统的核心进程和服务使用此类令牌执行系统级操作。
- 示例:
NT AUTHORITY\SYSTEM
账户通常在操作系统启动时使用,具有完全的系统级权限。
六、令牌的获取与修改
1. 获取令牌
开发人员或管理员可以通过 Windows 提供的 API 函数,如 OpenProcessToken
,来获取与进程关联的令牌。通过调用这些函数,可以提取进程的令牌,并进行进一步的分析或操作。
2. 修改令牌
在某些情况下,可能需要修改进程的令牌。例如,管理员可以使用 DuplicateTokenEx
API 来复制一个令牌,然后使用 SetPrivilege
等函数修改令牌中的权限,以提升或调整该进程的操作权限。
七、用户账户控制(UAC)与令牌
Windows 的 用户账户控制(UAC) 机制在用户执行需要管理员权限的操作时提供了额外的安全保护。当用户登录时,系统通常会创建两个令牌:一个是标准的用户令牌,另一个是具有完全管理员权限的令牌。在默认情况下,UAC 会限制标准令牌的权限,只有在用户明确同意时,系统才会使用具有管理员权限的令牌执行高权限操作。
UAC 和令牌的关系
-
UAC 提升令牌:
当用户尝试以管理员身份运行程序时,UAC 会创建一个具有更高权限的“提升令牌”(Elevated Token)。这个令牌会包含管理员权限。没有 UAC 提升的情况下,普通用户登录时会使用一个“标准令牌”(Standard Token),其权限会受到限制。- 标准令牌:包含用户的基本权限。
- 提升令牌:包括用户的基本权限和管理员权限。只有当用户明确同意提升权限(通过 UAC 提示)时,系统才会为进程生成这个令牌。
-
UAC 限制令牌权限:
即使用户是管理员,UAC 仍然会限制其令牌的权限,以减少对系统造成不必要的风险。例如,管理员登录时默认会生成一个带有有限权限的标准令牌,这个令牌不允许直接修改系统设置或执行敏感操作。只有当程序请求提升并且用户同意时,UAC 才会为其生成一个提升令牌。 -
UAC 控制令牌的使用:
每当用户启动程序时,UAC 会决定是否允许该程序获取管理员权限。如果允许,UAC 会提供一个提升令牌,该令牌在执行时会授予管理员权限;如果不允许,程序只能使用标准令牌,受限于普通用户的权限。
示例:UAC 和令牌的流程
-
普通用户登录:
用户登录时,系统为用户创建一个标准令牌,限制其权限。 -
程序请求提升权限:
当程序尝试以管理员权限运行时,UAC 会弹出提示,询问用户是否允许提升权限。如果用户同意,UAC 会为该程序创建一个提升令牌。 -
提升令牌执行:
程序在获得提升令牌后,可以执行需要管理员权限的操作。此时,程序会使用包含管理员权限的令牌,而非普通的标准令牌。 -
令牌恢复:
在某些情况下(例如,程序关闭),系统会恢复用户的标准令牌,继续执行普通权限的操作。
八、令牌窃取与安全问题
1. 令牌窃取
攻击者可能会尝试窃取高权限的进程令牌,利用窃取的令牌来提升自己的权限。这类攻击通常被称为“令牌劫持”或“令牌盗用”。通过获得系统或管理员级别的令牌,攻击者能够绕过常规的权限控制,从而获得未经授权的访问。
2. 令牌操作的审计
为了防止恶意行为,系统管理员可以启用审计日志,记录关于令牌操作的所有事件。通过审计令牌的创建、修改及访问记录,管理员可以检测潜在的安全问题,及时响应权限滥用或安全威胁。
九、总结
进程令牌在 Windows 操作系统的安全模型中发挥着至关重要的作用。它不仅决定了进程对资源的访问权限,还影响了系统的安全控制和权限管理。通过合理的令牌管理,Windows 可以确保不同进程的安全性,防止未授权操作的发生。同时,令牌的窃取和滥用可能会导致严重的安全漏洞,因此在实际应用中,开发人员和系统管理员需要特别关注令牌的管理、审计与安全性。
相关文章:
进程令牌:Windows 安全架构中的关键元素
一、进程令牌概述 进程令牌(Process Token)是 Windows 操作系统中一个重要的安全机制,它包含了与进程安全上下文相关的详细信息。每个进程在执行时都会关联一个进程令牌,令牌用于确定该进程可以访问哪些资源以及能执行哪些操作。…...

基于springboot的超时代停车场管理平台(源码+文档)
大家好我是风歌,曾担任某大厂java架构师,如今专注java毕设领域。今天要和大家聊的是一款基于springboot的超时代停车场管理平台。项目源码以及部署相关请联系风歌,文末附上联系信息 。 项目简介: 基于Spring Boot的超时代停车场…...
缓存穿透、缓存击穿、缓存雪崩的区别与解决方案
1. 缓存穿透(Cache Penetration) 定义:大量请求查询 数据库中不存在的数据,导致请求绕过缓存直接访问数据库,造成数据库压力过大。 场景: 恶意攻击:例如用不存在的用户ID频繁请求。 业务误操作…...
箭头函数的this指向谁
先看1个重要原则: 由Vue管理的函数,一定不要写箭头函数,箭头函数的this就不再是Vue实例了 箭头函数的 this 指向在定义时确定,继承自外层作用域(即定义时的上下文)的 this,且无法通过 call、app…...
【愚公系列】《Python网络爬虫从入门到精通》012-字符串处理
标题详情作者简介愚公搬代码头衔华为云特约编辑,华为云云享专家,华为开发者专家,华为产品云测专家,CSDN博客专家,CSDN商业化专家,阿里云专家博主,阿里云签约作者,腾讯云优秀博主,腾讯云内容共创官,掘金优秀博主,亚马逊技领云博主,51CTO博客专家等。近期荣誉2022年度…...
【Python】01-基础
目录 1、命令行简介1.1 命令行结构1.2 常用dos指令 2、环境变量2.1 查看2.2 添加2.3 修改2.4 删除 3、path环境变量4、进制5、文本文件和字符集6、Sublime使用 1、命令行简介 命令行就是文本交互页面,通过命令行可以使用指令来操作计算机 1.1 命令行结构 版本及版…...
Java-DFS(深度优先搜索)
原理 深度优先搜索的基本思路是从一个节点开始,依次访问它的每一个邻居节点,直到达到一个没有未被访问的邻居的节点为止。这个过程可以使用递归或者栈来实现。其特点是尽可能深入每一个分支,然后再回溯。 DFS算法常用于解决以下类型的问题&…...
AI大模型编程能力对比:DeepseekClaudeGemini
在当今快速发展的技术领域,人工智能(AI)模型在编程和数据处理方面的应用越来越广泛。不同的AI模型因其独特的设计理念和技术优势,适用于不同的编程任务和场景。 本文将对三种主流的AI模型——DeepSeek v3、Gemini Flash 2.0 和 C…...
用C++实现点到三角形最小距离的计算
1、全部代码 #include <iostream> #include <cmath> #include <array> #include <algorithm>// 二维点结构体 struct Point2D {double x, y;Point2D(double x 0, double y 0) : x(x), y(y) {} };// 计算点到线段的最小距离 double pointToSegmen…...
解决前后端日期传输因时区差异导致日期少一天的问题
前端处理 1. 发送日期字符串而非时间戳 在前端使用日期选择器(如 el-date-picker)获取日期后,将日期转换为特定格式的字符串(如 YYYY-MM-DD)发送给后端,避免直接发送带有时区信息的时间戳或日期对象。这样…...

mmsegmentation自己的数据集+不同网络的config配对
比如说我们要用这个网络: 我们发现他内部继承了很多类,要想配对我们的数据集,就要进行父类的修改。 ../_base_/models/deeplabv3_unet_s5-d16.py, ../_base_/datasets/drive.py,../_base_/default_runtime.py, ../_base_/schedules/schedule…...

Golang官方编程指南
文章目录 1. Golang 官方编程指南2. Golang 标准库API文档 1. Golang 官方编程指南 Golang 官方网站:https://go.dev/ 点击下一步,查看官方手册怎么用 https://tour.go-zh.org/welcome/1 手册中的内容比较简单 go语言是以包的形式化管理函数的 搜索包名…...
ram的使用——初始化很重要
背景 ram是非常常用的ip,前人的经验告诉我们,如果不对ram进行初始化直接读写,不定态在实际上板时会出现不可预知的问题。 我们需要对ram进行初始化写0操作,代码如下。需要注意,复位释放时立马写入可能存在复位抖动的…...
doris:最佳实践
异步物化视图使用原则 时效性考虑: 异步物化视图通常用于对数据时效性要求不高的场景,一般是 T1 的数据。如果时效性要求高,应考虑使用同步物化视图。 加速效果与一致性考虑: 在查询加速场景,创建物化视图时&#x…...

[创业之路-299]:图解金融体系结构
一、金融体系结构 1.1 概述 金融体系结构是一个国家以行政的、法律的形式和运用经济规律确定的金融系统结构,以及构成这个系统的各种类型的银行和非银行金融机构的职能作用和相互关系。以下是对金融体系结构的详细分析: 1、金融体系的构成要素 现代金…...

RL--2
强化学习当中最难的两个点是: 1.reward delay; 2.agent的行为会影响到之后看到的东西,所以agent要学会探索世界; 关于强化学习的不同类型,可以分为以下三种: 一种是policy based:可以理解为它是…...
[JVM篇]分代垃圾回收
分代垃圾回收 分代收集法是目前大部分 JVM 所采用的方法,其核心思想是根据对象存活的不同生命周期将内存划分为不同的域,一般情况下将 GC 堆划分为老生代(Tenured/Old Generation)和新生代(Young Generation)。老生代的特点是每次垃圾回收时只有少量对象…...

Dify本地安装
目录 方式一docker安装: 方式二源码安装: Dify本地安装可以用docker方式,和源码编译方式。 先到云厂商平台申请一台Centos系统云主机,网络选择海外,需要公网IP,再按一下流程操作: 方式一doc…...

python | 两招解决第三方库安装难点
前言 python 被广泛应用的原因之一,便是拥有大量的第三方库,涵盖 web 开发、数据分析和机器学习等多个方面。 对于多数初学者来说,如何成功安装 python 第三方库成为了一大难点,总是因各种原因导致安装失败。 本文以自身经验&a…...

stm32mp15x 之 M4 使用 canfd
目录 序配置添加注坑参考 序 在使用 stm32mp15x 系列时,M4 有不少的坑,这里简单聊聊使用 canfd 时遇到的一些问题。 配置 这里使用 PLL4R 为 100M,用于 CANFD 的时钟 canfd 速率配置成 1M ,5M,其中数据传输速率为 5M…...
DockerHub与私有镜像仓库在容器化中的应用与管理
哈喽,大家好,我是左手python! Docker Hub的应用与管理 Docker Hub的基本概念与使用方法 Docker Hub是Docker官方提供的一个公共镜像仓库,用户可以在其中找到各种操作系统、软件和应用的镜像。开发者可以通过Docker Hub轻松获取所…...

Swift 协议扩展精进之路:解决 CoreData 托管实体子类的类型不匹配问题(下)
概述 在 Swift 开发语言中,各位秃头小码农们可以充分利用语法本身所带来的便利去劈荆斩棘。我们还可以恣意利用泛型、协议关联类型和协议扩展来进一步简化和优化我们复杂的代码需求。 不过,在涉及到多个子类派生于基类进行多态模拟的场景下,…...
可靠性+灵活性:电力载波技术在楼宇自控中的核心价值
可靠性灵活性:电力载波技术在楼宇自控中的核心价值 在智能楼宇的自动化控制中,电力载波技术(PLC)凭借其独特的优势,正成为构建高效、稳定、灵活系统的核心解决方案。它利用现有电力线路传输数据,无需额外布…...
【HTML-16】深入理解HTML中的块元素与行内元素
HTML元素根据其显示特性可以分为两大类:块元素(Block-level Elements)和行内元素(Inline Elements)。理解这两者的区别对于构建良好的网页布局至关重要。本文将全面解析这两种元素的特性、区别以及实际应用场景。 1. 块元素(Block-level Elements) 1.1 基本特性 …...

BCS 2025|百度副总裁陈洋:智能体在安全领域的应用实践
6月5日,2025全球数字经济大会数字安全主论坛暨北京网络安全大会在国家会议中心隆重开幕。百度副总裁陈洋受邀出席,并作《智能体在安全领域的应用实践》主题演讲,分享了在智能体在安全领域的突破性实践。他指出,百度通过将安全能力…...
css3笔记 (1) 自用
outline: none 用于移除元素获得焦点时默认的轮廓线 broder:0 用于移除边框 font-size:0 用于设置字体不显示 list-style: none 消除<li> 标签默认样式 margin: xx auto 版心居中 width:100% 通栏 vertical-align 作用于行内元素 / 表格单元格ÿ…...
Rapidio门铃消息FIFO溢出机制
关于RapidIO门铃消息FIFO的溢出机制及其与中断抖动的关系,以下是深入解析: 门铃FIFO溢出的本质 在RapidIO系统中,门铃消息FIFO是硬件控制器内部的缓冲区,用于临时存储接收到的门铃消息(Doorbell Message)。…...

有限自动机到正规文法转换器v1.0
1 项目简介 这是一个功能强大的有限自动机(Finite Automaton, FA)到正规文法(Regular Grammar)转换器,它配备了一个直观且完整的图形用户界面,使用户能够轻松地进行操作和观察。该程序基于编译原理中的经典…...

技术栈RabbitMq的介绍和使用
目录 1. 什么是消息队列?2. 消息队列的优点3. RabbitMQ 消息队列概述4. RabbitMQ 安装5. Exchange 四种类型5.1 direct 精准匹配5.2 fanout 广播5.3 topic 正则匹配 6. RabbitMQ 队列模式6.1 简单队列模式6.2 工作队列模式6.3 发布/订阅模式6.4 路由模式6.5 主题模式…...

Ubuntu Cursor升级成v1.0
0. 当前版本低 使用当前 Cursor v0.50时 GitHub Copilot Chat 打不开,快捷键也不好用,当看到 Cursor 升级后,还是蛮高兴的 1. 下载 Cursor 下载地址:https://www.cursor.com/cn/downloads 点击下载 Linux (x64) ,…...