ACTF2020文件上传漏洞实战:绕过Apache解析限制的三种策略

1. 从灯泡图标到一句话木马:ACTF2020 Upload题初探

那天晚上,我正刷着CTF题目,碰上了ACTF2020的这道Upload题。一打开页面,啥也没有,就一个孤零零的灯泡图标在那亮着。我当时还愣了一下,心想这题目设计得挺有意思。把鼠标往灯泡上一放,嘿,上传文件的选择框就出来了。这种交互设计在CTF里不算常见,但挺直观的,就是告诉你:这儿能传文件,漏洞也在这儿。

既然是文件上传,我的第一反应和所有搞渗透测试的朋友一样——先看看有没有前端校验。右键查看页面源代码,果然在js文件里找到了猫腻。代码里明明白白写着,只允许上传jpgpnggif这三种图片后缀的文件。这种前端校验太常见了,基本上就是防君子不防小人,用Burp Suite一抓包就能改掉。但题目肯定不会这么简单,后端肯定还有别的招等着呢。

我习惯性地准备了一个最基础的一句话木马文件,内容是这样的:

GIF89a
<?php @eval($_POST[1])?>

开头那个GIF89a是个小技巧,这是GIF图片的文件头标识。加上它,是为了应对一些比较基础的、会检查文件内容类型的检测机制,让文件看起来更像一个“合法”的图片。我把这个文件保存为shell.php,然后顺手把后缀改成了.png,准备上传。

用Burp Suite拦截上传请求,再把后缀从.png改回.php,这是我测试文件上传漏洞的标准流程。但这次,服务器返回了“nonono~ Bad file!”。这个提示很明确,后端不认.php这个后缀。这时候,我心里大概有了两个方向:要么是后端有一个很严格的后缀黑名单,直接把php给禁了;要么就是它对文件内容进行了更深度的检测,发现这不是一个真正的图片。

为了验证到底是哪种情况,我换了个思路。我不改包了,就直接把那个带着GIF89a文件头、但内容是PHP代码的.png文件传上去。结果页面显示“Upload Success!”,并且给了我一个访问路径。这说明,后端并没有深入检查文件内容里是不是藏了PHP代码,它拦截的关键点,就是.php这个后缀名。问题一下子清晰了:我们的目标就是想方设法,让服务器把我们上传的、含有代码的文件,当成PHP脚本来执行。

2. 巧用.user.ini:让图片“变身”PHP的第一次尝试

既然直接传.php文件行不通,我就开始琢磨别的路子。在PHP的世界里,有一个不太起眼但威力巨大的配置文件,叫做.user.ini

内容概要:本文系统研究了线性模型预测控制(LMPC)与非线性模型预测控制(NMPC)在四旋翼无人机轨迹跟踪任务中的控制性能对比,基于Matlab/Simulink平台搭建完整的仿真控制系统。研究内容涵盖四旋翼无人机的动力学建模、状态空间表达、线性与非线性预测模型构建、滚动时域优化求解以及系统约束处理等关键技术环节,重点从轨迹跟踪精度、动态响应速度、系统稳定性及抗干扰能力等方面对两种控制策略进行对比分析,深入探讨线性化近似方法与精确非线性模型在实际控制效果上的差异,为无人机高性能飞控系统的设计提供理论支撑与仿真验证依据; 适合人群:具备自动控制原理、非线性系统理论、无人机动力学及Matlab/Simulink仿真基础的研究生、科研人员以及从事无人飞行器控制算法开发的工程技术人员; 使用场景及目标:① 掌握模型预测控制(MPC)在强非线性系统如四旋翼中的具体应用方法;② 理解LMPC与NMPC在建模假设、优化求解及控制性能上的本质差异;③ 为相关课题的仿真系统搭建、控制算法选型与性能评估提供实践参考;④ 支持课程设计、学位论文撰写或科研项目的算法验证与结果分析; 阅读建议:建议结合提供的Simulink仿真模型,深入剖析状态预测、代价函数设计与实时滚动优化的实现机制,对比不同飞行工况(如高机动轨迹)下的仿真结果,重点关注NMPC在复杂动态环境中的性能优势以及LMPC在计算效率与实时性方面的潜力,同时应注意非线性优化带来的计算负担问题及其对工程可实现性的影响。
内容概要:本文档为一篇关于“基于超局部模型无模型预测电流控制(MFPCC)+自抗扰ESO观测器改进模型预测控制仿真”的论文复现资源,重点介绍了在Simulink环境下对三相逆变器系统进行建模与控制策略仿真的研究。核心内容聚焦于采用无模型预测电流控制(MFPCC)结合自抗扰控制中的扩张状态观测器(ESO)来提升系统对参数不确定性与外部干扰的鲁棒性,优化电流环动态响应性能。文中通过构建超局部模型规避精确系统建模的难题,利用MFPCC实现快速动态响应,并引入ESO实时估计并补偿系统内外部扰动,从而增强整体控制精度与稳定性。通过与传统控制方法的对比仿真,充分验证了该复合控制策略在抑制扰动、提高电流跟踪精度及改善系统鲁棒性方面的优越性,文档同时提供了完整的Simulink仿真模型与实现代码,便于读者复现、调试与深入研究。; 适合人群:具备电力电子、自动控制理论基础,熟悉Simulink仿真环境,从事电机控制、新能源并网、电力变换器控制或预测控制算法研究的研究生、科研人员及工程技术人员。; 使用场景及目标:① 复现并掌握MFPCC与ESO相结合的先进复合控制策略;② 深入研究无模型预测控制在电力电子系统中的具体应用与实现方法;③ 探索自抗扰控制中ESO观测器在扰动估计与补偿、提升系统鲁棒性方面的关键作用与设计要点;④ 作为毕业设计、科研课题、学术论文复现或工程项目开发的重要技术参考与原型验证平台。; 阅读建议:建议读者结合现代控制理论与电力电子技术基础知识,首先深入理解MFPCC的无模型预测原理与ESO的扰动观测机理,再逐步导入并调试所提供的仿真模型,重点关注控制器参数的整定过程、系统在不同工况下的抗扰性能测试与动态响应指标分析,同时可参考文档中列出的其他相关案例进行横向比较与综合学习,以达到融会贯通的效果。
在仓库管理、商品盘点或快递发货时,你是不是也经常被条码打印折腾得够呛——每次都要手动输入条码数字,用Word画个条码再调整大小,打印出来不是太宽就是太窄,扫码枪扫半天识别不了;遇到批量生成几十个条码时,更是一个个复制粘贴到手抽筋。大飞哥软件自习室——条码生成器正是为解决这些高频痛点而设计的一款专业条码工具。它的核心定位是:将扫码枪识别、条码生成、自动打印与批量导出整合为一体,支持Code128等主流条码格式,用户只需扫描或输入内容,即可自动生成尺寸统一、清晰可扫的条码,适配仓库、零售、物流等多种场景,大幅提升标签制作效率。 这款软件的核心功能围绕扫码枪自动打印、条码尺寸精细控制、批量生成与PDF导出三大模块构建。扫码枪自动打印模块是它最硬核的效率利器:连接扫码枪后,只需勾选“扫描后自动打印”,扫描条码后软件自动识别内容并生成对应条码图片,再直接发送到打印机,全程无需手动输入任何数字。条码尺寸精细控制模块允许用户自定义条码高度(10-50mm)、模块宽度(0.1-1.0mm)以及文字距离(0-20mm),调整后预览区域实时更新,确保打印出的每一张条码大小统一、扫描通过率极高。批量生成与PDF导出模块支持手动输入多行内容或从文本文件批量导入,一次性生成最多100个条码,并可一键导出为A4布局的PDF文件,每页放置8个条码,方便批量打印和分发。 在实际使用场景中,这款工具的实用价值覆盖了从个体商户到企业仓库的广泛需求。电商仓库管理员每天需要打印大量快递面单上的条码,使用扫码枪扫描快递单号后自动生成条码并打印,比手动打字快五倍以上,而且条码尺寸统一,扫描枪识别率接近100%。零售店商品管理员为新到货的商品制作价格标签时,可以先将所有商品SKU整理成一个文本文件,批量导入软件,统一设置条码高度和模块宽度后导出为PDF,一次打印几十张标签,贴上去整洁专业。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值