hackmyvm: hopper
信息收集到获取第一个shell
PORT STATE SERVICE
22/tcp open ssh
80/tcp open http
全端口扫描,先访问一下web服务。 data:image/s3,"s3://crabby-images/5d2a8/5d2a82b9c196a5706cd5c43ee5e0d35ebefdd75c" alt="index" 利用gobuster扫描目录找到目录advanced-search ,这里存在ssrf。 data:image/s3,"s3://crabby-images/adbea/adbea0f1984739558bc3f314af41b486385be582" alt="dirb" data:image/s3,"s3://crabby-images/ec612/ec612bfc0291d6316e532f045809e6c285b6b1df" alt="ssrf" 虚拟机有三个用户可以bash登录,root ,edward ,henry 。
经过简单测试,不能进行远程文件包含,估计是调用的curl_exec ,关于php的ssrf利用一般情况下可以参看SSRF in PHP [1]进行利用。但是这里有点特别,没有redis,没有mysql,于是对主机端口进行了探测。
#!/usr/bin/python3
import requests
for port in range(1,65535):
res = requests.get('http://192.168.143.191/advanced-search/path.php?path=http://127.0.0.1:%d' % port)
if len(res.text) == 0:
continue
else:
print('-----------------------')
print('port %d\n' % port)
print(res.text)
print('-----------------------')
扫描得到新的端口为2222 。 data:image/s3,"s3://crabby-images/a801d/a801df34cb22b9bc9b2816f3185505266570bc5f" alt="2222" 紧接着是目录发现,爆破目录,发现存在目录backup 。 data:image/s3,"s3://crabby-images/d2366/d2366756856f1ec8ef7fdc0951d8fc280f8d71fb" alt="backup" 发现是一个passpharse的sshkey,于是使用john进行解密,参看JTR(John The Ripper)的ssh密钥破解记录 [2],得到passpharse为barcelona 。 data:image/s3,"s3://crabby-images/6ddef/6ddefd7412d478c836c93abe1785ce3fc8a0cfe3" alt="pass" 利用id_rsa登录ssh成功登录用户edward 获取用户flag。 data:image/s3,"s3://crabby-images/5b0fe/5b0fe921e086f44569767e691098aba00e0e7a44" alt="在这里插入图片描述"
切换用户
往/var/www/html 目录中写入一个反弹shell的php木马,成功获取用户www-data 。 data:image/s3,"s3://crabby-images/e2056/e2056d6542d11deb99f8aded7261aabb3feee689" alt="www-data" 查看该用户具有sudo权限。 data:image/s3,"s3://crabby-images/aec5e/aec5ee9e9095cdc2e519dc79164d80f16d44f3a5" alt="sudo" 参考GTFOBins [3],切换至用户henry (需要注意的运行程序前需要先设置环境变量export TERM=xterm )。 data:image/s3,"s3://crabby-images/bb860/bb8606f47942a091d2abaa92b68e864bdd727f5a" alt="henry"
提权至root
查看用户henry的sudo权限。 data:image/s3,"s3://crabby-images/0930a/0930a7144f56a1a955a769e8ac6ac44bc61f8d0e" alt="henrysudo" 这个就比较简单了,改/etc/passwd 。
将passwd复制到tmp目录中,将root用户中的x 替换为已知加密密码。 data:image/s3,"s3://crabby-images/c6702/c6702d8d2fb74c5654236c0e8c0de7eff8fdc51e" alt="editpasswd" 然后使用命令henry@hopper:/tmp$ sudo /usr/bin/ascii-xfr -rv /etc/passwd < passwd 将修改后的passwd写入/etc/passwd。使用su,成功切换至root获取flag。 data:image/s3,"s3://crabby-images/24879/2487926c44bd88a9b55d51f217696b6a50724ba7" alt="rootflag"
参考
[1] https://blog.csdn.net/bylfsj/article/details/105083164 [2] https://blog.csdn.net/qq_40490088/article/details/97812715 [3] https://gtfobins.github.io/
|