您现在的位置是:数据库 >>正文
如何恢复网络令牌,你学会了吗?
数据库9447人已围观
简介在这篇文章中,我将介绍我在逆转Office的身份验证机制时发现的两个问题,并提供一些不需要删除内存的POC工具来帮助恢复存储的令牌。微软账户服务我必须承认,当我第一次开始研究这个问题时,删除我正在运行 ...
在这篇文章中 ,何恢我将介绍我在逆转Office的复网身份验证机制时发现的两个问题,并提供一些不需要删除内存的络令POC工具来帮助恢复存储的令牌。
微软账户服务我必须承认 ,牌学当我第一次开始研究这个问题时 ,何恢删除我正在运行的复网Word进程的内存并没有发现文档签名eyJ0eX。这是络令当前工具用来识别活动令牌的主要方法,我在Windows登录时使用Microsoft 365帐户。牌学
事实证明,云计算何恢Microsoft Account (MSA)的复网身份验证令牌处理方式与通常的Azure AD SSO帐户不同。
让我们从查看经过MSA验证的络令Office会话开始,启动Microsoft Office并查看加载的牌学DLL 。其中最突出的何恢是MicrosoftAccountWAMExtension.dll 。将这个DLL加载到Ghidra中,复网我们可以开始寻找为MSA帐户生成身份验证令牌的络令原因。
如果我们在这个DLL中寻找RPC调用,就可以看到一堆被定向到名为wlidsvc的服务 :

不幸的香港云服务器是 ,微软并没有为RPC调用此服务提供IDL(或者根本没有提供很多信息),所以我们将不得不做一些逆向工程来解决这个问题。
让我们将WinDBG附加到wlidsc并监视正在进行的RPC调用 。在任何Office进程中进行身份验证之后,我们看到第一个调用是RPC方法WLIDCCreateContext以创建上下文,然后是WLIDCAcquireTokensWithNGC,最后是一系列其他调用,我们将暂时忽略这些调用。
如果我们在后一种方法中添加一个断点,那登录到Office中的服务器租用MSA帐户会导致命中 :

步进式(Stepping )直到我们点击ret并检查填充的参数,在参数12的内存区域中会显示一些有趣的东西 。

对我来说,这确实是一个象征!如果我们打开像Fiddler这样的代理,我们会看到它与Office访问web服务时使用的身份验证令牌格式相匹配 :

那么 ,我们如何从我们自己的工具中调用它呢?让我们使用James Forshaw的NtObjectManager生成一个可以使用的存根 。模板下载

生成的RPC存根根据Windows版本的不同而不同,这是毫无价值的,例如,在Windows 10中,我们发现字段计数在输入结构上发生了变化,因此,如果你收到可怕的(0x800706F7) - The stub received bad data. 错误,请多家留意。
使用RPC客户端存根创建一个快速的C#应用程序 ,我们将重播我们之前观察到的源码库入站RPC调用,并添加参数,这将给我们提供如下内容 :

如果我们称之为 :

由于这是MSA身份验证请求 ,我们将不得不使用Substrate等服务来访问Microsoft 365服务。旋转一个代理并在Office中导航是确定调用什么以及这些web服务采用什么参数的最佳方式。但你可以看到,passport令牌返回后,我们可以很好地进行身份验证和交互:

现在我们已经了解了如何恢复MSA,那么Azure AD呢 ?通过Lee Christensen的帖子知道,我们可以很容易地按需请求新令牌 ,但是我们在Office进程中看到的亿华云缓存令牌被转储了,它们是如何在启动时加载的呢?
让我们提供一个新的主机并将我们的用户帐户与AzureAD相关联,然后登录到Office ,再尝试找出令牌存储的位置 。

为了确保我们在正确的轨道上 ,让我们从内存中转储一些字符串 ,并确保eyJ0eX签名存在。

我们再次深入搜索dll,但这次我们将重点关注Windows.Security.Authentication.Web.Core.dll 。
这是一个WinRT库 ,因此我们需要深入Ghidra了解正在发生的事情。
AddWebTokenResponseToCache方法如下:

如果我们进一步研究 ,会发现此方法实际上负责将凭据缓存到序列化文件 ,这些文件可以在%LOCALAPPDATA%\Microsoft\TokenBroker\Cache中找到 。

好的,让我们看看这些TBRES文件:

如果我们使用ProcMon ,我们会看到这些文件确实在进程启动时被Office访问:

可以看到,这就是我们的身份验证信息存储的地方!查看JSON会发现一个IsProtected字段 。在WinDBG中 ,我们将附加到Office,在CryptUnprotectData上添加断点并重新启动 。果然,我们发现base64解密数据的内容被解密了。

JSON文件中我们特别感兴趣的字段是ResponseBytes,我添加了一个带有快速工具的repo ,该工具可以解密这些文件,可以在这里找到。
在使用ProtectedData.Unprotect解密此数据后 ,我们看到了明文JWT。果然 ,解密它们会得到我们之前从内存中看到的相同信息 :

来自不同提供者和应用程序的其他令牌也存储在这些文件中 ,包括MSA令牌,这也是毫无价值的。
现在我们知道了 ,Windows和Office用于Live和Azure的认证和缓存会话的几种不同方法 。
POC可以在https://github.com/xpn/WAMBam上找到。
本文翻译自 :https://blog.xpnsec.com/wam-bam/如若转载,请注明原文地址
Tags:
转载:欢迎各位朋友分享到网络,但转载请说明文章出处“商站动力”。http://www.noorid.com/html/216b899775.html
下一篇:CSO失业的九种方式
相关文章
可用于保护物联网设备的十个物联网安全提示
数据库物联网是一把双刃剑。虽然拥有一个带有智能锁的智能家居和一个可以自动煮沸早茶水的 Wi-Fi 水壶让生活变得更加简单,但它的价格可能比价格标签上的价格要高得多。在物联网安全中,存在安全权衡,不幸的是,这 ...
【数据库】
阅读更多win10重装系统后桌面上的文件如何找回解决方法
数据库我们在重装完系统以后,很多的用户们会发现之前在桌面上的文件都都不见了,这些文件都不显示,那么这个文件都需要怎么去找回恢复呢,快来看看详细的教程吧~win10重装系统后桌面上的文件如何找回解决方法:1、 ...
【数据库】
阅读更多win10怎么用自带的软件进行磁盘分区
数据库当我们电脑重装系统后发现磁盘只有一个,没有分区,这个时候时候为了方便管理,很多小伙伴都希望多几个分区,但是又不想下载乱七八糟的软件进行分区,这个时候就得用到系统自带的分区软件,下面小编整理了自带软件进 ...
【数据库】
阅读更多
热门文章
最新文章
友情链接
- 解决未安装音频输出设备的问题(如何在没有音频输出设备的情况下获得音频输出?)
- i54590处理器的性能及特点剖析(了解i54590处理器的主要特性及其在计算机领域的应用)
- 联想B41-80优盘安装系统教程(快速、简单地为联想B41-80电脑安装操作系统)
- 大庆移动光线50m(突破速度极限,大庆移动光线50m为你带来全新上网体验)
- OPPO N3云空间为什么只有5G
- HTC M8口袋模式如何开启
- MotoZ信号表现如何?(探索MotoZ在各种信号环境下的表现和关键特性)
- 三星galaxy xcover3配置怎么样
- SupremeFXS1220音效技术评测(探索SupremeFXS1220音效芯片的卓越性能与创新功能)
- 什么是PDU?如何为数据中心选择合适的PDU 企业服务器源码库云服务器b2b信息平台亿华云网站建设香港物理机