当前位置: 首页 > ai >正文

Webug4.0靶场通关笔记16- 第16关MySQL配置文件下载

目录

第16关 MySQL配置文件下载

1.打开靶场

2.源码分析

3.渗透实战

(1)Windows系统

(2)Linux系统

4、防御方法


本文通过《webug4.0靶场第16关MySQL配置文件下载》来进行渗透实战。文件下载是指 Web 应用程序在处理文件下载功能时,由于代码逻辑缺陷或安全措施不足,导致用户可以非法下载服务器上的敏感文件。 

第16关 MySQL配置文件下载

1.打开靶场

打开webug4靶场的第16关任意文件下载,完整URL地址以及页面如下所示。

http://192.168.71.1/webug4/control/filedownload/ini_file_download.php

构造下载文件地址,如下所示。

http://192.168.71.1/webug4/control/filedownload/ini_file_download.php?file=template/assets/img/1.txt
http://192.168.71.1/webug4/control/filedownload/ini_file_download.php?file=template/assets/img/2.txt

2.源码分析

分析可知代码对参数file未做任何过滤, 直接使用fread进行处理,存在任意文件下载,具体如下所示。

<?php// 引入公共配置文件,包含路径定义、数据库连接等基础功能
require_once "../../common/common.php";// 会话验证:检查用户是否已登录,未登录则重定向到登录页面
if (!isset($_SESSION['user'])) {header("Location:../login.php");
}// 处理文件下载请求:当用户通过GET方法传递file参数时
if (isset($_GET["file"])) {// 检查参数是否存在且不为空if (!empty($_GET["file"])) {// 构造文件路径:将用户提供的file参数与网站根路径拼接$filePath = ROOTPATH . $_GET['file'];// 提取文件扩展名(最后4个字符)$fileName = substr($filePath, -4);// 检查文件是否存在if (file_exists($filePath)) {// 以二进制模式打开文件$file = fopen($filePath, 'rb');// 设置响应头:指定内容类型为二进制流Header("Content-type: application/octet-stream");// 设置响应头:允许按字节范围请求(断点续传支持)Header("Accept-Ranges: bytes");// 设置响应头:指定文件大小Header("Accept-Length: " . filesize($filePath));// 设置响应头:强制下载并指定文件名(固定前缀"a" + 原扩展名)header('Content-Disposition: attachment; filename=a' . $fileName);// 读取文件内容并输出到浏览器echo fread($file, filesize($filePath));// 关闭文件资源fclose($file);// 终止脚本执行,防止后续内容输出exit();}}
}// 引入HTML模板文件,通常包含文件下载表单或链接列表
require_once TPMELATE."/file_download.html";

这段 PHP 代码实现了一个基于会话验证的文件下载功能。首先检查用户会话,确保只有登录用户可访问该页面。当用户通过 GET 参数传递文件名时,代码将其与网站根路径拼接构造完整文件路径,并提取文件扩展名的最后 4 个字符。接着检查文件是否存在,若存在则设置响应头信息(包括内容类型、文件大小等),并强制以固定前缀 "a" 加原扩展名的文件名下载。文件内容通过二进制模式读取并输出到浏览器。若文件不存在或未传递有效参数,则加载文件下载页面模板。该功能存在目录遍历、任意文件下载等安全风险,需加强输入验证和路径控制。

其实这个源码与上一关完全一致,对比如下所示。

3.渗透实战

相对而言是需要构造MySQL的配置文件的相对路径。

(1)Windows系统

file=../../Extensions/MySQL5.7.26/my.ini

 如下所示下载了ini文件,渗透成功。

(2)Linux系统

如下所示,webug容器的mysql.ini文件的路径如下所示。

/usr/share/php5/mysql/mysql.ini

源码的根路径如下所示。

/var/www/html

相对而言mysql.ini的相对路径如下所示。

../../../usr/share/php5/mysql/mysql.ini

如下所示渗成功下载ini文件,渗透成功。

4、防御方法

文件下载可能导致很多问题,比如敏感信息泄露和恶意软件感染。

  • 敏感数据外泄: 攻击者可下载包含用户凭证、财务记录或商业机密等敏感信息的文件,导致数据泄露,对个人隐私和企业运营造成重大损害。

  • 恶意软件感染: 下载文件可能携带病毒、木马等恶意程序,在设备上植入后实施数据窃取、远程控制或发起后续攻击。

为有效预防文件下载,可从输入验证、文件存储管理、安全配置、日志监控等多个方面采取措施。

预防层面具体措施简要说明
输入验证白名单验证限定合法文件名、类型及路径,仅允许下载白名单内文件
路径验证严格校验文件路径,防止目录遍历攻击,避免直接用用户输入拼接路径
文件存储管理文件隔离将可下载文件与敏感数据分开放置,设置合理访问权限
文件名处理规范文件名,剔除特殊字符,防止恶意篡改
安全配置HTTP 头设置通过设置 Content-Disposition 等头信息,确保文件以安全方式下载
CSP 策略利用内容安全策略,限制页面资源加载来源,防范恶意文件执行
日志监控与审计日志记录记录文件下载请求相关信息,便于追溯异常行为
实时监控借助 IDS 或 IPS 实时监测,及时阻断可疑下载操作
代码管理代码审查定期检查文件下载功能代码,排查验证不严格等
安全测试运用工具与手动测试结合,全面检测潜在安全隐患
http://www.xdnf.cn/news/10215.html

相关文章:

  • 【前端】SPA v.s. MPA
  • C58-字符串拼接函数strcat
  • Unity3D仿星露谷物语开发56之保存角色位置到文件
  • 姜老师MBTI课程:4条轴线的总结
  • FactoryBean 接口
  • SOC-ESP32S3部分:21-非易失性存储库
  • Visual Stuido笔记:C++二进制兼容性之间的兼容性
  • C#中实现两个对象部分相同属性值的复制
  • 系统思考:化繁为简的艺术
  • 磨皮功能 C++/C的OpenCV 实现
  • C# 类和继承(使用基类的引用)
  • DeepSeek 赋能金融反洗钱:AI 驱动的风险监测革新之路
  • Mysql库的操作和表的操作
  • 【C++高级主题】命令空间(五):类、命名空间和作用域
  • java8集合操作全集
  • FreeCAD源码分析: 串行化工具
  • 深入解析 Dotnet-Boxed.Framework:提升 .NET 开发效率的利器
  • Matlab程序设计基础
  • DeepSeek-R1-0528,官方的端午节特别献礼
  • PostgreSQL ERROR: out of shared memory处理
  • QT6引入QMediaPlaylist类
  • 进程同步:生产者-消费者 题目
  • cf每日刷题
  • RFID技术深度剖析:从原理、协议到S50卡与FM17550读写
  • 多类别分类中的宏平均和加权平均
  • SOC-ESP32S3部分:22-分区表
  • springMVC-9数据格式化
  • rtpinsertsound:语音注入攻击!全参数详细教程!Kali Linux教程!
  • CppCon 2014 学习:Multiplatform C++
  • 具有离散序列建模的统一多模态大语言模型【AnyGPT】