返回
Featured image of post DCShadow 攻击

DCShadow 攻击

go!

DCShadow 攻击

背景

2018 年 1 月 24 日,Benjamin Delpy(神器 Mimikatz 的作者)和 Vincent Le Toux 在 BlueHat IL 会议期间公布了针对域活动目录的一种新型攻击技术 DCShadow。在具备域管理员权限条件下,攻击者可以创建伪造的域控制器,将预先设定的对象或对象属性复制到正在运行域服务器中。

**DCSync 从域服务器复制出东西,DCShadow 是将数据复制至域服务器。**Luc Delsalle 对这种技术进行了验证和详细的描述,并就红蓝对抗中蓝队对抗此种攻击技术的缺陷和补救方法。

从 DCShadow 目前展示的功能来看,主要只能用于红蓝对抗的隐蔽后门。但是 DCShadow 第一次澄清和实现了伪造一个 DC 的最小需求合集,这个贡献非常大。以前很多攻击方法都卡在不能伪造域服务器,例如 MS15-011 和 MS15-014 等,有了 DCShadow 的基础,应该会有很多新的攻击方法。

流程

DCShadow 的攻击过程包括 3 个主要个步骤:

  • 在目标域的 AD 活动目录注册一个伪造的 DC
  • 使伪造的 DC 被其他的 DC 认可,能够参与域复制
  • 强制触发域复制,将指定的新对象或修改后的对象属性同步复制到其他 DC 中

注册伪造 DC

一台机器要想注册成为域中的一台 DC 服务器,需要在域的活动目录中注册一个 NTDS-DSA(nTDSDSA)类对象。注册的位置为 CN=Servers,CN=Default-First-Site-Name,CN=Sites,CN=Configuration,DC=adsec,DC=com

adsec.com 域有 3 台域服务器,分别是 LABDC01、RESDC01 及 WIN2016-DC01。测试机器为 Win7X86cn04,如果 DCShadow 测试成功的话,则会生成一个新的NTDS-DSA(nTDSDSA)类对象:

查看 CN=Servers,CN=Default-First-Site-Name,CN=Sites,CN=Configuration,DC=adsec,DC=com的安全描述符,可知必须有域管理员权限才具备写权限

所以发动 DCShadow 攻击首先必须具备域管理员权限。

认可 DC

一个刚注册的 DC 要想被域中其他DC认可,能够参与域复制,需要满足 3 个条件:

  • 这台伪造 DC 具备认证凭证,能认证到域,即有域内账号,可以使用机器账号,实验环境中为 WIN7X86CN04$
  • 伪造 DC 能认证其他 DC 来访问的账号,通过给 WIN7X86CN04$ 添加 SPN,可以实现这一点。关键是需要添加哪些SPN,DCShadow 的一个大贡献是找到 了 SPN 的最小合集,只需要 2 个即可:DRS服务(GUID 为 E3514235–4B06–11D1-AB04–00C04FC2DCD2) 和 GC(Global Catalog)服务

  • 运行 DRS 服务,最少需要实现 IDL_DRSBind、IDL_DRSUnbind、IDL_DRSGetNCChanges、IDL_DRSUpdateRefs 这 4 个 RPC 接口,以便其他 DC 能够通过 RPC 获取需要复制的数据。Mimikatz 工具的最新版已经集成了这 4 个接口

发起复制

通常负责域复制和同步的进程是 KCC 进程,默认时间是 15 分钟校验一次,如果需要复制则发起;也可以使用 Windows 域服务器自带的系统工具 repadmin,该工具会调用 DRSReplicaAdd 函数接口强制立即发起域复制,DCShadow 正是通过调用·DRSReplicaAdd 函数强制立即发起域复制。

Licensed under CC BY-NC-SA 4.0
Built with Hugo
Theme Stack designed by Jimmy