基本信息
端口扫描
常规22和80:
data:image/s3,"s3://crabby-images/2f199/2f1994fd1e191c2e0432b9ae06cf14fb46ad5739" alt=""
80
需要加一下host:
1 | 10.10.10.183 forwardslash.htb |
data:image/s3,"s3://crabby-images/16ddc/16ddc2438accbabb2cc66bf44700abe28fd105c6" alt=""
扫一下目录:
1 | gobuster dir -u http://forwardslash.htb/ -w /usr/share/wordlists/dirb/common.txt -x php,txt |
发现一个note.txt:
data:image/s3,"s3://crabby-images/e3f6d/e3f6d4d648dc4d1adfd187016ca1eb1648909d19" alt=""
data:image/s3,"s3://crabby-images/69377/6937721e00d1d718d2589415670ea46acd75ea95" alt=""
1
2
3
4 Pain, we were hacked by some skids that call themselves the "Backslash Gang"... I know... That name...
Anyway I am just leaving this note here to say that we still have that backup site so we should be fine.
-chiv
backup site
根据提示信息以及vhost扫描,找到backup.forwardslash.htb,同样加到hosts里:
1 | gobuster vhost -u http://forwardslash.htb/ -w /usr/share/wordlists/dirb/common.txt |
data:image/s3,"s3://crabby-images/bf390/bf390d21b3787ce02ed92072ff64b39bc2f98bcd" alt=""
data:image/s3,"s3://crabby-images/8afe9/8afe91ff61000b4579dd70592810edea6fc933c0" alt=""
注册账号登录进去,这个功能有个可疑的地方:
data:image/s3,"s3://crabby-images/9e190/9e1904dadb045458bbfb6f766f85d74794a7d12d" alt=""
data:image/s3,"s3://crabby-images/31122/311227219f936c824eb806396b59151531c2ad3c" alt=""
取消disable测试,发现是post一个url参数:
data:image/s3,"s3://crabby-images/64ee3/64ee36dd80540b74c86f9a0e3e72a46e38a064f2" alt=""
LFI
这里有一个明显的LFI:
/etc/passwd
data:image/s3,"s3://crabby-images/b096a/b096a1f7946adcd4691ba3f6a9efa85a6638760c" alt=""
根据passwd文件得到两个用户名:
1 | pain:x:1000:1000:pain:/home/pain:/bin/bash |
config.php
直接读取config.php得到数据库配置信息:
data:image/s3,"s3://crabby-images/e5266/e526665b23bde74bdf0a36d6237022481cb95f96" alt=""
1 | define('DB_USERNAME', 'www-data'); |
api.php
部分文件直接读没权限可以用php伪协议:
data:image/s3,"s3://crabby-images/71444/714440dddd44a33eb3c3439c81d72f79a180f8bd" alt=""
data:image/s3,"s3://crabby-images/4fdd8/4fdd87f1cd152f1709729c95c7252e3e63d41feb" alt=""
dev/index.php
得到chiv账号密码:
data:image/s3,"s3://crabby-images/f8cb9/f8cb9db9fbf50707d275f9bc10b78adec74e6c80" alt=""
1 | chiv : N0bodyL1kesBack/ |
chiv ssh
用这个账号密码能ssh登录chiv,但user.txt在另一个用户目录里:
data:image/s3,"s3://crabby-images/e6b2c/e6b2cc695910a8d6adc136c82c895cb39ac8b973" alt=""
backup 条件竞争
存在/var/backups目录和/usr/bin/backup程序, 直接使用报错:
data:image/s3,"s3://crabby-images/3db95/3db9530144d75c8b8921d8691b2f7ce49d9f2cab" alt=""
根据报错信息,可以利用条件竞争:
1 | cat shell.sh |
得到pain用户密码:
data:image/s3,"s3://crabby-images/0a098/0a098ce1936d83ffbdb4a07af83f7bae1fbf1f4f" alt=""
1 | define('DB_USERNAME', 'pain'); |
user flag
切换到pain用户,得到user.txt:
data:image/s3,"s3://crabby-images/24168/24168bd0bb819c932d06f3ced6301b5d55726f3b" alt=""
encryptorinator
在这个目录有一个加密文本和加解密代码:
data:image/s3,"s3://crabby-images/30f65/30f6548104648ccd01363c53797cea424ace6804" alt=""
根据代码写一个解密程序爆破key,获得message:
1 | def decrypt(key, msg): |
结果:
1 | python miao.py |
信息
根据结果得到这个加密的img:
1 | /var/backups/recovery/encrypted_backup.img |
并且sudo -l
能够看到当前用户可以无密码cryptsetup以及指定目录mount:
data:image/s3,"s3://crabby-images/7d4fd/7d4fd24d25e3db0bbb7b9390262defd19af38b2b" alt=""
pain用户目录也有个note.txt说明这些:
1 | cat note.txt |
decrypt & mount
1 | sudo /sbin/cryptsetup luksOpen /var/backups/recovery/encrypted_backup.img backup |
里面是一个SSH私钥:
data:image/s3,"s3://crabby-images/4eb42/4eb4264221539c4a42f5f053e36f208e82c2089b" alt=""
root flag
使用这个私钥可以ssh登录root,得到root.txt:
data:image/s3,"s3://crabby-images/e06fb/e06fbc7e9cf73d402bea91e4470ec3c6a26624cb" alt=""
参考资料
https://sushant747.gitbooks.io/total-oscp-guide/local_file_inclusion.html
Hackthebox Forwardslash Walkthrough - YouTube
https://www.youtube.com/watch?v=hSGOLMgr5bw