2.9 会话、窗口站、桌面和窗口消息:图形界面背后的“分层舞台”

news2026/4/30 1:10:47
个人主页杨利杰YJlio❄️个人专栏《Sysinternals实战教程》 《Windows PowerShell 实战》 《WINDOWS教程》 《IOS教程》《微信助手》 《锤子助手》 《Python》 《Kali Linux》《那些年未解决的Windows疑难杂症》让复杂的事情更简单让重复的工作自动化文章目录1. 写在前面为什么要理解 Windows 图形界面的“分层舞台”2. 会话 Session同一台机器上的多场登录环境2.1 会话到底是什么2.2 Session 0 为什么特殊2.3 在 Process Explorer 中怎么看 Session3. 窗口站 Window Station会话里的窗口容器3.1 窗口站是什么3.2 窗口站解决了什么问题3.3 窗口站与安全隔离的关系4. 桌面 Desktop真正展示给用户看的那块画布4.1 桌面不是壁纸而是安全对象4.2 为什么锁屏后窗口没有消失4.3 UAC 为什么普通脚本点不了5. 窗口消息 Window Messages窗口之间的“喊话协议”5.1 什么是窗口消息5.2 为什么窗口消息也涉及安全5.3 运维排障中怎么理解窗口消息问题6. Sysinternals 视角如何把这些概念用于排障6.1 用 Process Explorer 看 Session ID6.2 排查服务无法弹窗6.3 排查远程桌面多用户问题6.4 排查 UAC 自动化失败7. 我的理解这几个概念应该怎么记8. 总结图形界面不是一块屏幕而是一套分层安全结构1. 写在前面为什么要理解 Windows 图形界面的“分层舞台”在前面几节中我们已经学习了进程、线程、句柄、用户模式、内核模式、应用隔离、应用容器、受保护进程、调用栈和符号等 Windows 内部机制。这些内容更多是在回答一个问题程序是怎么运行的系统资源是怎么被访问的而这一节要继续往图形界面方向推进重点回答另一个更贴近桌面支持的问题同一台 Windows 电脑上为什么可以同时存在本地登录、远程桌面、锁屏界面、UAC 安全桌面、系统服务和用户桌面很多时候我们在排查问题时会遇到这些现象服务程序明明启动了但用户桌面上看不到窗口远程桌面用户 A 的程序和用户 B 的程序互相看不见UAC 弹窗出现时普通脚本无法自动点击锁屏后窗口没有消失但用户暂时无法操作Process Explorer 里看到多个explorer.exe但它们属于不同用户或不同 Session。这些现象背后不是 Windows “玄学”而是 Windows 图形子系统中的四个关键概念会话Session窗口站Window Station桌面Desktop窗口消息Window Messages一句话概括会话决定“谁登录在哪一场”窗口站决定“这一场有哪些窗口资源”桌面决定“当前展示哪块画布”窗口消息决定“窗口之间如何通信”。先用一张总览图建立整体框架这张图可以帮助我们先建立一个整体理解Windows 图形界面不是单层结构而是一套分层舞台。会话 Session窗口站 Window Station桌面 Desktop窗口 Window窗口消息 Window Messages本地登录 / 远程桌面 / 服务会话输入输出资源 / 剪贴板 / 菜单对象Default / Winlogon / Secure DesktopWM_CREATE / WM_PAINT / WM_KEYDOWN2. 会话 Session同一台机器上的多场登录环境2.1 会话到底是什么在 Windows 中每一次交互式登录都会对应一个Session ID。可以简单理解为一次登录就是一个会话。比如场景典型 Session系统服务Session 0本地登录用户Session 1第一个远程桌面用户Session 2第二个远程桌面用户Session 3所以当你在一台服务器上看到多个用户同时登录时本质上就是多个 Session 同时存在。这也是远程桌面服务能够实现“一台机器多人同时在线”的基础。从图中可以看出Session 0主要承载系统服务Session 1可能是本地登录用户Session 2 / 3可能是不同的远程桌面用户每个 Session 内都有自己的用户空间、桌面和进程。2.2 Session 0 为什么特殊在早期 Windows 中服务和用户程序之间的隔离没有现在严格服务有时可以直接和用户桌面交互。但这会带来严重安全风险如果高权限服务可以随便在用户桌面弹窗低权限程序也可能通过窗口消息反向攻击高权限服务。所以从 Windows Vista 之后Windows 引入了Session 0 Isolation。也就是说系统服务主要运行在Session 0用户桌面运行在Session 1、2、3……服务默认不再直接和用户桌面交互这就是为什么很多服务类程序“明明运行了”但用户界面却看不到。2.3 在 Process Explorer 中怎么看 Session在 Sysinternals 的 Process Explorer 中可以通过以下方式查看进程所属会话View → Select Columns → Process Image → 勾选 Session ID观察重点services.exe通常位于 Session 0用户自己的explorer.exe通常位于当前登录 Session远程桌面用户的程序会显示不同的 Session ID多个同名进程不一定属于同一个用户环境。排查远程桌面、服务弹窗、用户会话异常时Session ID 是非常关键的第一层坐标。3. 窗口站 Window Station会话里的窗口容器3.1 窗口站是什么理解完 Session 后再往下一层就是Window Station。可以这样理解窗口站是一个会话内部用于管理图形窗口、输入输出资源和部分共享对象的容器。它通常包含键盘输入鼠标输入剪贴板菜单对象一个或多个 Desktop。其中用户最常接触的是WinSta0它是典型的交互型窗口站。这张图中可以看到Session 里面包含 Window StationWindow Station 里包含共享的输入 / 输出资源Window Station 下面还可以继续包含多个 Desktop最常见的交互窗口站就是WinSta0。3.2 窗口站解决了什么问题窗口站主要解决的是同一会话中哪些进程可以共享图形输入输出环境。例如谁能接收键盘鼠标输入谁能访问剪贴板谁能创建可见窗口谁和谁处在同一个图形交互环境中。如果进程不在正确的窗口站里它就算启动了也未必能正常显示 GUI。3.3 窗口站与安全隔离的关系窗口站不是单纯的图形概念它也有安全意义。因为图形界面不仅仅是“显示窗口”还涉及输入信息剪贴板内容窗口消息用户交互权限。所以 Windows 不允许所有进程随便共享同一套窗口资源。窗口站是 Windows 图形界面安全边界的一部分尤其和窗口消息、UIPI、完整性级别等机制密切相关。4. 桌面 Desktop真正展示给用户看的那块画布4.1 桌面不是壁纸而是安全对象很多人一听到“桌面”第一反应是壁纸、图标、任务栏。但在 Windows Internals 的视角里Desktop 不是背景图片而是一个图形对象。可以这样理解Desktop 是 Window Station 下面真正承载窗口显示和用户交互的那块逻辑画布。一个 Window Station 可以包含多个 Desktop例如Desktop 类型作用Default Desktop用户日常看到的普通桌面Winlogon Desktop登录、锁屏、安全登录界面Secure DesktopUAC 提示等高安全交互界面这张图非常适合理解“桌面切换”平时看到的是Default Desktop锁屏或登录时切换到Winlogon DesktopUAC 提示可能切换到Secure Desktop同一时刻通常只有一个 Desktop 是当前活动界面。4.2 为什么锁屏后窗口没有消失当我们按下Win L系统并不是把当前所有窗口都关掉也不是把它们“最小化”。真正发生的是系统从当前用户的 Default Desktop 切换到了 Winlogon Desktop。所以原来的窗口仍然存在原来的程序仍然运行只是当前显示和输入焦点切换到了另一个 Desktop登录回来后原来的窗口还在。这也是为什么锁屏前打开的文档、浏览器、资源管理器窗口在解锁后还能继续显示。4.3 UAC 为什么普通脚本点不了很多自动化脚本会遇到一个问题UAC 提示出现后脚本无法自动点击“是”。这不是脚本写错了而是 Windows 有意这样设计。因为 UAC 提示通常运行在更高安全级别的桌面上普通用户进程所在的桌面无法随便控制它。如果低权限脚本可以随便点击 UAC 提示那就等于低权限程序可以自动完成高权限授权整个安全机制会被打穿。所以在排查“自动化脚本无法操作 UAC 窗口”时要先判断这是不是Desktop 隔离和权限隔离导致的正常现象。5. 窗口消息 Window Messages窗口之间的“喊话协议”5.1 什么是窗口消息在 Windows GUI 编程模型中窗口之间并不是随意通信的而是通过消息机制来驱动界面行为。常见窗口消息包括消息含义WM_CREATE窗口创建WM_DESTROY窗口销毁WM_PAINT请求窗口重绘WM_SIZE窗口大小变化WM_KEYDOWN键盘按键按下WM_LBUTTONDOWN鼠标左键按下简单说窗口消息就是 Windows 图形界面的事件通信机制。如果把 GUI 程序看成一个个窗口那么窗口消息就是这些窗口之间进行交互的“通信协议”。5.2 为什么窗口消息也涉及安全窗口消息看起来只是 GUI 行为但它背后有安全风险。典型风险就是历史上的Shatter Attack低权限进程向高权限窗口发送恶意窗口消息高权限窗口错误处理消息攻击者借此影响高权限进程行为。为了解决这类问题Windows 引入了多层保护完整性级别Integrity LevelUIPIUser Interface Privilege Isolation会话隔离桌面隔离权限边界。现代 Windows 不允许低权限进程随便给高权限窗口发送危险消息这是安全设计不是系统异常。5.3 运维排障中怎么理解窗口消息问题在桌面支持场景中窗口消息机制经常体现在这些问题里自动化脚本无法控制管理员窗口普通程序无法操作 UAC 提示框服务程序无法弹出用户可见窗口不同远程桌面会话之间看不到彼此窗口某些程序只有在当前登录用户桌面中运行才正常。遇到这类问题时不要只从“软件有没有启动”判断还要问这个进程在哪个 Session在哪个 Desktop它的完整性级别是多少它有没有资格给目标窗口发送消息6. Sysinternals 视角如何把这些概念用于排障理解概念只是第一步真正有价值的是把它们用到排障中。在 Sysinternals 工具链里最常用的是Process ExplorerProcess MonitorAutorunsHandleProcDump对于本节内容最直接相关的是 Process Explorer。6.1 用 Process Explorer 看 Session ID建议在 Process Explorer 中启用以下列View → Select Columns → Process Image勾选Session IDUser NameIntegrity LevelCommand LineImage Path这样你就能快速判断进程属于哪个用户进程在哪个 Session是否运行在管理员权限是否属于服务进程是否是远程桌面用户启动的程序。6.2 排查服务无法弹窗如果用户反馈服务程序运行了但桌面没有弹窗。不要直接判断软件坏了可以按下面思路排查是否服务程序没有弹窗进程是否在 Session 0服务与用户桌面隔离检查用户会话和桌面状态改用托盘程序/客户端程序与服务通信检查权限、完整性级别、窗口站和桌面推荐做法是使用“服务 用户态客户端”的架构而不是让服务直接弹 GUI。6.3 排查远程桌面多用户问题在多用户 RDP 环境中如果发现用户 A 的程序无法影响用户 B多个explorer.exe同时存在某个进程只在某个远程用户中出现优先查看Session ID User Name判断它到底属于哪个登录环境。不要只看进程名同名进程可能属于完全不同的用户会话。6.4 排查 UAC 自动化失败如果自动化脚本无法点击 UAC检查脚本运行权限检查目标窗口完整性级别判断是否切换到了 Secure Desktop不建议通过绕过安全边界的方式处理。更规范的方式是使用管理员权限启动必要程序使用企业软件分发工具使用计划任务或服务端授权机制通过标准化脚本提升前置权限。7. 我的理解这几个概念应该怎么记如果只背定义很容易混乱。我建议用一个“剧场模型”来记Windows 概念类比理解作用Session一场登录演出区分不同用户登录环境Window Station这一场演出的舞台系统管理输入输出和窗口资源Desktop当前展示的具体舞台承载窗口和交互界面Window Messages舞台上角色之间的喊话驱动窗口事件与交互一句话记忆Session 是“谁在哪一场”Window Station 是“这一场的窗口空间”Desktop 是“当前看到的画布”Window Messages 是“窗口之间的通信”。再结合排障角度现象优先检查服务弹窗看不到Session 0 IsolationRDP 多用户混淆Session IDUAC 自动点击失败Secure Desktop / UIPI程序窗口不显示Window Station / Desktop跨进程 UI 操作失败Integrity Level / Window Messages8. 总结图形界面不是一块屏幕而是一套分层安全结构这一节看起来讲的是 Windows 图形界面其实本质上讲的是Windows 如何在同一台机器上隔离不同用户、不同权限、不同交互环境。可以用三句话总结第一会话 Session让一台机器可以同时承载多个登录环境本地用户、远程用户和系统服务可以各自运行在不同 Session 中。第二窗口站和桌面共同构成 Windows 图形界面的分层舞台锁屏、登录、UAC、安全桌面本质上都和 Desktop 切换有关。第三窗口消息是 GUI 程序之间的通信机制但它受到 Session、Desktop、完整性级别和 UIPI 的多重限制所以低权限程序不能随便控制高权限窗口。当我们用 Sysinternals 工具分析桌面问题时不应该只看“进程是否存在”还要看它属于哪个 Session、哪个用户、哪个完整性级别以及它是否处在正确的图形交互边界内。到这里第 2 章关于 Windows 系统内部结构的关键积木已经基本串起来了管理员权限进程、线程、作业用户模式和内核模式句柄应用程序隔离应用容器受保护进程调用栈和符号会话、窗口站、桌面和窗口消息这些概念不是孤立的术语而是我们后续使用 Sysinternals 排查复杂 Windows 问题时的底层地图。 返回顶部点击回到顶部

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2558111.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…