如何恢复网络令牌,你学会了吗?
在这篇文章中 ,何恢我将介绍我在逆转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/如若转载 ,请注明原文地址
相关文章
大数据时代,数据是市场竞争的重要资源,因此利用网络爬虫恶意爬取数据的事件频繁发生。今年上半年,某银行电子结算中心承建的线上征信平台“某某融”,就遭到了恶意爬虫的疯狂“洗劫”。某金融征信平台疑似遭爬虫疯2025-12-07
个性化定制手机字体,让你的手机与众不同(改变手机字体,轻松实现个性化风格)
如今,手机已成为人们生活中不可或缺的工具。然而,在众多相似的手机中,我们是否希望能够让自己的手机与众不同,展示出独特的个性风格?改变手机字体是一种简单而有效的方法,通过这个小小的改变,你可以为你的手机2025-12-07
华为Mate10保时捷是华为与保时捷合作推出的一款旗舰手机,融合了华为顶级科技与保时捷独特的奢华元素。它不仅仅是一部功能强大的手机,更是豪华与性能的完美结合。在这篇文章中,我们将深入探索华为Mate12025-12-07
国产平板电脑的性能如何?(探究国产平板电脑的关键优势与劣势)
随着科技的不断发展,平板电脑已经成为人们生活中必不可少的工具之一。在国内市场上,国产平板电脑也逐渐崭露头角。本文将深入探讨国产平板电脑的性能表现,旨在帮助读者更好地了解这一产品。一、外观设计与质量:国2025-12-07
随着ChatGPT风靡全球,其开发商OpenAI就接连不断地面临着越来越多的质疑与批评。近日,OpenAI就陷入了接连“吃官司”的状态之中。6月29日,有16 名匿名人士向美国加利福尼亚州旧金山联邦法2025-12-07
解决戴尔电脑程序错误的有效方法(掌握关键步骤,轻松排除戴尔电脑程序错误)
随着计算机的普及和应用,戴尔电脑成为众多用户的首选。然而,使用过程中难免会遇到程序错误的情况,这给用户带来了困扰。本文将提供一些有效的方法和关键步骤,帮助用户解决戴尔电脑程序错误,让您的电脑运行更加顺2025-12-07

最新评论