data:image/s3,"s3://crabby-images/506ee/506ee2e69aa0715402fbf634440199f7fd471d13" alt=""
我将继续发布解决方案,以期从HackTheBox平台完成计算机的最终定稿。
在本文中,我们将深入研究LDAP,解码VNC密码,反编译dotNet应用程序,轻松解密AES以及恢复已删除的Active Directory对象。
与实验室的连接是通过VPN。建议您不要从工作计算机或有重要数据的主机连接,因为您会发现自己与某个对信息安全有所了解的人处于私有网络中。
侦察
这台机器的IP地址为10.10.10.182,我将其添加到/ etc / hosts中。
10.10.10.182 cascade.htb
第一步是扫描打开的端口。由于使用nmap扫描所有端口会花费很长时间,因此我将首先使用masscan进行扫描。我们以每秒500个数据包的速度扫描来自tun0接口的所有TCP和UDP端口。
masscan -e tun0 -p1-65535,U:1-65535 10.10.10.182 --rate=500
data:image/s3,"s3://crabby-images/c9134/c9134fdec41f90a2d3a77d3fc2db777a270ab2ea" alt=""
主机上打开了许多端口。现在,让我们用nmap对其进行扫描以过滤并选择所需的对象。
nmap cascade.htb -p49172,49157,49154,135,53,5985,636,389,139,49155,445,3269,3268,49158,88
data:image/s3,"s3://crabby-images/d876e/d876e82a5eda3c835c997d99eabf191d13136daf" alt=""
现在,要获取有关端口上运行的服务的更多详细信息,请使用-A选项运行扫描。
nmap -A cascade.htb -p49172,49157,49154,135,53,5985,636,389,139,49155,445,3269,3268,49158,88
data:image/s3,"s3://crabby-images/3975f/3975f833e160ee5de596cf30493f9c2cbbc6f54e" alt=""
像往常一样,首先要做的是首先列出SMB-enum4linux。
enum4linux -a cascade.htb
data:image/s3,"s3://crabby-images/833c9/833c935915da58e04881afe5fad8a3232eee2b6a" alt=""
data:image/s3,"s3://crabby-images/a14a1/a14a14cec912a17d5ae9b726c411c906c82bfbf4" alt=""
我们为自己保存了用户及其组成员的列表。让我们看看LDAP必须提供什么。
入口点
我们使用JXplorer处理LDAP。连接并查看所有对象。
data:image/s3,"s3://crabby-images/99bca/99bca13fb1bc80a4650e55a20b9188d808e06e95" alt=""
从用户Ryan Thompson那里,我们找到了cascadeLegacyPwd属性。
data:image/s3,"s3://crabby-images/45017/4501710f94ecfc5cc8ecb49aa52f8c1b9a1e5051" alt=""
我们解码base64并获得密码。
data:image/s3,"s3://crabby-images/f47c4/f47c4436afef06857c6b39a2ee5d36ff6410dd0e" alt=""
用户
找到凭据后,让我们使用CrackMapExec查看可供我们使用的SMB资源。
cme smb cascade.htb -u "r.thompson" -p "rY4n5eva" --shares
data:image/s3,"s3://crabby-images/cb7b8/cb7b8854e749ba2cf434aed84db03b8d7edd4c85" alt=""
让我们连接到数据资源。
smbclient -U r.thompson //10.10.10.182/Data
data:image/s3,"s3://crabby-images/fa5ee/fa5ee73742a4e049ea484f96f0e556931bc85ad2" alt=""
让我们递归地进行所有操作。
data:image/s3,"s3://crabby-images/f3958/f39587d4ab437e31abacf488335dfdfa2caebd68" alt=""
现在,让我们下载并查看这些文件。
get "IT\Email Archives\Meeting_Notes_June_2018.html"
get "IT\Logs\Ark AD Recycle Bin\ArkAdRecycleBin.log"
get IT\Logs\DCs\dcdiag.log
get "IT\Temp\s.smith\VNC Install.reg"
在第一个文件中,他们讨论了网络传输,并且TempAdmin密码与常规管理员密码相同。
data:image/s3,"s3://crabby-images/3383b/3383b2c8a031be04305bc0ac62b52a24cc3c61cc" alt=""
在第二个文件中,请自己注意用户ArkSvc的权限。
data:image/s3,"s3://crabby-images/2593e/2593ec7dd3db73ee07516f6eba3bd96eae367e0e" alt=""
第三个文件中没有有趣的东西。但是在第四部分中,我们找到了s.smith用户的VNC密码。
data:image/s3,"s3://crabby-images/5a736/5a73699461711f4c8c16c9d7b0e2024f1dbdac47" alt=""
我们使用vncpasswd对其进行解码。我们指示我们要解码密码(-d)并以十六进制形式传递它。
vncpasswd.py -d -H 6bcf2a4b6e5aca0f
data:image/s3,"s3://crabby-images/7b154/7b154ba0e2dbc97abe29502f23e8a36427efcdc5" alt=""
如果查看enum4linux的输出,可以看到该用户是“远程管理用户”组的成员。让我们尝试使用该密码通过winrm服务登录。
evil-winrm -i cascade.htb -u s.smith -p sT333ve2
data:image/s3,"s3://crabby-images/e2a0d/e2a0dc58686920567ffe5236952f3c27166d54ba" alt=""
用户2
让我们看看该用户的SMB资源:
cme smb cascade.htb -u s.smith -p sT333ve2 --shares
data:image/s3,"s3://crabby-images/d031d/d031d44aec73c0140508942fcec294f6178f641e" alt=""
可用审计$资源。
smbclient -U s.smith //10.10.10.182/Audit$
data:image/s3,"s3://crabby-images/55dc7/55dc7a98df2f254186d850d287c167a9fcc70993" alt=""
让我们下载所有内容。
data:image/s3,"s3://crabby-images/659ba/659ba85c0ac9d022a9954e363c8a1362f2759a42" alt=""
在下载的文件中有一个数据库,通过打开数据库,您可以在LDAP表中输入凭据。
data:image/s3,"s3://crabby-images/ce94c/ce94c90d4aa6d1fb9551f8a38f77c1893e8d87c5" alt=""
但是它们并不适合任何地方,显然密码是加密的,但是可以使用该程序解密。在这种情况下,存在CascCrypto.dll。而且,程序和库都是用C#编写的。
data:image/s3,"s3://crabby-images/7547a/7547a5844e52ee18c923475672916b093a17b6da" alt=""
让我们使用dnSpy反编译程序。我们找到了从数据库读取密码并将其转移到解密功能的位置。密钥也被转移到那里。
data:image/s3,"s3://crabby-images/b507b/b507b60e2ca14bf40d81fa9e8e943e12d05d1be3" alt=""
对库进行反编译后,我们找到了加密模式和初始化向量。
data:image/s3,"s3://crabby-images/ee4cb/ee4cb5e0b0edfddb98c9a975eb615b7202894df3" alt=""
因此,我们具有以下参数:
data:image/s3,"s3://crabby-images/581d4/581d430777e8165aae9fef8e7031f7f5440ca44a" alt=""
现在我们需要解密。让我们在CyberChef网站上进行操作。
data:image/s3,"s3://crabby-images/bd71e/bd71e14542bc241826f230d574c8efa928f6b49a" alt=""
然后我们得到了密码。如下enum4linux所示,该用户属于“远程管理用户”和“ AD回收站”组。您可能还记得,需要该用户来传输对象。并且TempAdmin用户具有与管理员相同的密码。但是它已被删除。
让我们看一下远程对象。
Get-ADObject -IncludeDeletedObjects -Filter {IsDeleted -eq $True}
data:image/s3,"s3://crabby-images/43d13/43d13938122ac57d10198466ff491e64d299f359" alt=""
然后我们找到了想要的对象。让我们获取其属性。
Get-ADObject -Filter {SamAccountName -eq 'TempAdmin'} -IncludeDeletedObjects -Properties *
data:image/s3,"s3://crabby-images/1dc22/1dc22f97683676914e1025c60092bdd7f7ed87fe" alt=""
然后我们解码密码。
data:image/s3,"s3://crabby-images/e56f8/e56f8aec39ad30ee712b6329915e30dfa5fcea23" alt=""
让我们连接到WinRM并进行标记。
evil-winrm -i cascade.htb -u Administrator -p baCT3r1aN00dles
data:image/s3,"s3://crabby-images/a2cd2/a2cd258f62c664236485f6a6d4cfcbdf16a90a98" alt=""
您可以通过Telegram加入我们。在这里,您可以找到有趣的资料,泄漏的课程和软件。让我们建立一个社区,在这个社区中,将有很多IT领域的专家,然后我们可以在任何IT和信息安全问题上互相帮助。