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

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 实时监测,及时阻断可疑下载操作
代码管理代码审查定期检查文件下载功能代码,排查验证不严格等
安全测试运用工具与手动测试结合,全面检测潜在安全隐患

相关文章:

  • 项目日记 -Qt音乐播放器 -搜索模块
  • Linux研学-用户解析
  • 【Java笔记】Spring IoC DI
  • ApiHug 1.3.9 支持 Spring 3.5.0 + Plugin 0.7.4 内置小插件升级!儿童节快乐!!!
  • 新闻数据加载(鸿蒙App开发实战)
  • flowable候选人及候选人组(Candidate Users 、Candidate Groups)的应用包含拾取、归还、交接
  • neo4j 5.19.0安装、apoc csv导入导出 及相关问题处理
  • 内容中台构建数字化管理新路径
  • 每日c/c++题 备战蓝桥杯(P1204 [USACO1.2] 挤牛奶 Milking Cows)
  • 【多线程初阶】死锁的产生 如何避免死锁
  • 每日c/c++题 备战蓝桥杯(P2240 【深基12.例1】部分背包问题)
  • 湖北理元理律师事务所:债务管理中的人本主义实践
  • 如何在 Ubuntu22.04 上安装并开始使用 RabbitMQ
  • 【代码坏味道】无用物Dispensables
  • 如何查看电脑电池性能
  • 92. Java 数字和字符串 - 字符串
  • 跟单业务并发量分析
  • 将 node.js 项目作为后台进程持续运行
  • 强网杯 2024 PyBlockly
  • RuoYi前后端分离框架实现前后端数据传输加密(一)之后端篇
  • 快速做网站公司/国际实时新闻
  • 网站开发服务费/关键词吉他谱
  • 北京天通苑 做网站/教育培训网站官网
  • javaweb可以做网站吗/seo编辑培训
  • 帝国网站数据库配置文件/明年2024年有疫情吗
  • 网站建设 长沙/南宁seo网站排名优化公司