Resource-based Constrained Delegation
学习和实践 AWS 黑客技术:HackTricks 培训 AWS 红队专家 (ARTE) 学习和实践 GCP 黑客技术:HackTricks 培训 GCP 红队专家 (GRTE)
Resource-based Constrained Delegation 的基础
这与基本的 Constrained Delegation 类似,但不是给一个对象权限以冒充任何用户对服务。Resource-based Constrained Delegation 设置在对象中谁能够冒充任何用户。
在这种情况下,受限对象将具有一个名为 msDS-AllowedToActOnBehalfOfOtherIdentity 的属性,包含可以冒充任何其他用户的用户的名称。
与其他委派相比,这种受限委派的另一个重要区别是,任何对计算机帐户具有写权限的用户(GenericAll/GenericWrite/WriteDacl/WriteProperty/etc)都可以设置 msDS-AllowedToActOnBehalfOfOtherIdentity(在其他形式的委派中,您需要域管理员权限)。
新概念
在受限委派中提到,用户的 userAccountControl 值中的 TrustedToAuthForDelegation
标志是执行 S4U2Self 所需的。但这并不完全正确。
实际上,即使没有该值,如果您是服务(具有 SPN),也可以对任何用户执行 S4U2Self,但是,如果您具有 TrustedToAuthForDelegation
,返回的 TGS 将是可转发的,如果您没有该标志,返回的 TGS 将不会是可转发的。
然而,如果在 S4U2Proxy 中使用的 TGS 不是可转发的,尝试滥用基本的受限委派将不起作用。但如果您尝试利用基于资源的受限委派,它将有效(这不是漏洞,而是一个特性,显然)。
攻击结构
如果您对计算机帐户具有写等效权限,则可以在该计算机上获得特权访问。
假设攻击者已经对受害者计算机具有写等效权限。
攻击者破坏一个具有SPN的帐户或创建一个(“服务 A”)。请注意,任何管理员用户_在没有其他特殊权限的情况下最多可以创建 10 个 计算机对象(MachineAccountQuota_**)**并为其设置一个 SPN。因此,攻击者可以创建一个计算机对象并设置一个 SPN。
攻击者滥用其对受害者计算机(ServiceB)的写权限,以配置基于资源的受限委派,允许 ServiceA 冒充任何用户对该受害者计算机(ServiceB)。
攻击者使用 Rubeus 执行完整的 S4U 攻击(S4U2Self 和 S4U2Proxy),从服务 A 到服务 B,针对具有对服务 B 的特权访问的用户。
S4U2Self(来自被破坏/创建的 SPN 帐户):请求管理员的 TGS 给我(不可转发)。
S4U2Proxy:使用上一步的不可转发 TGS请求从管理员到受害主机的TGS。
即使您使用的是不可转发的 TGS,由于您正在利用基于资源的受限委派,它将有效。
攻击者可以传递票证并冒充用户以获得对受害者 ServiceB的访问。
要检查域的 MachineAccountQuota,您可以使用:
攻击
创建计算机对象
您可以使用 powermad 在域内创建计算机对象**:**
配置基于资源的受限委派
使用 activedirectory PowerShell 模块
使用 powerview
执行完整的 S4U 攻击
首先,我们创建了新的计算机对象,密码为 123456
,因此我们需要该密码的哈希值:
这将打印该账户的 RC4 和 AES 哈希。 现在,可以执行攻击:
您只需使用 Rubeus 的 /altservice
参数询问一次即可生成更多票证:
请注意,用户有一个属性叫做“无法被委托”。如果用户将此属性设置为 True,您将无法冒充他。此属性可以在 bloodhound 中查看。
访问
最后一条命令将执行 完整的 S4U 攻击,并将 TGS 从管理员注入到受害主机的 内存 中。 在此示例中,已请求从管理员获取 CIFS 服务的 TGS,因此您将能够访问 C$:
滥用不同的服务票证
了解可用的服务票证在这里。
Kerberos 错误
KDC_ERR_ETYPE_NOTSUPP
: 这意味着 kerberos 配置为不使用 DES 或 RC4,而您仅提供了 RC4 哈希。至少向 Rubeus 提供 AES256 哈希(或者同时提供 rc4、aes128 和 aes256 哈希)。示例:[Rubeus.Program]::MainString("s4u /user:FAKECOMPUTER /aes256:CC648CF0F809EE1AA25C52E963AC0487E87AC32B1F71ACC5304C73BF566268DA /aes128:5FC3D06ED6E8EA2C9BB9CC301EA37AD4 /rc4:EF266C6B963C0BB683941032008AD47F /impersonateuser:Administrator /msdsspn:CIFS/M3DC.M3C.LOCAL /ptt".split())
KRB_AP_ERR_SKEW
: 这意味着当前计算机的时间与 DC 的时间不同,kerberos 无法正常工作。preauth_failed
: 这意味着给定的用户名 + 哈希无法登录。您可能忘记在生成哈希时在用户名中放入“$”(.\Rubeus.exe hash /password:123456 /user:FAKECOMPUTER$ /domain:domain.local
)KDC_ERR_BADOPTION
: 这可能意味着:您尝试模拟的用户无法访问所需的服务(因为您无法模拟它或因为它没有足够的权限)
请求的服务不存在(如果您请求 winrm 的票证但 winrm 没有运行)
创建的 fakecomputer 已失去对易受攻击服务器的权限,您需要将其恢复。
参考文献
学习和实践 AWS 黑客攻击:HackTricks 培训 AWS 红队专家 (ARTE) 学习和实践 GCP 黑客攻击:HackTricks 培训 GCP 红队专家 (GRTE)
Last updated