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

ctf show web入门99

打开靶场,通过代码审计我们发现这是一道通过合法的参数绕过条件限制,最终利用 file_put_contents 实现任意文件写入的题目,我们的主要目的就是把一个木马写入该网站,然后拿flag

$allow=array();for($i=36;$i<0x36d;$i++){array_push($allow,rand(1,$i));}

这串代码的意思是重复877-36次每次迭代rand(1, $i) 生成一个 1 到i之间的随机整数arraypush(i 之间的随机整数array_push(i之间的随机整数arraypush(allow, …) 将该随机数追加到 $allow 数组的末尾

数组 $allow 的变化

假设执行前 $allow 未定义(或为空),PHP 会将其自动创建为数组(但会抛出一个 Notice: Undefined variable)。建议先 $allow = [];。 最终 $allow 是一个索引数组,键从 0 到 840,共 841 个元素。

随机数的范围

第 1 轮($i=36):随机范围 [1, 36] 第 2 轮($i=37):范围 [1, 37] ... 最后一轮($i=876):范围 [1, 876] 随着循环进行,随机数的上限逐渐增大,后面生成的数值可能更大(但仍然是均匀分布的整数)

所以1到36包含在这个数组的可能性最大

if(isset($_GET['n'])&&in_array($_GET['n'],$allow)){file_put_contents($_GET['n'],$_POST['content']);}

条件:我们需要传入一个 $_GET[‘n’],并且这个值必须存在于 $allow 数组中。

结果:如果条件满足,程序会创建/写入一个名为 $_GET[‘n’] 的文件,内容为 $_POST[‘content’]。

这道题的破绽在于 PHP 的 弱类型比较。

在 PHP 中,in_array(value, array) 函数默认是弱类型检查(没有设置第三个参数为 true)。当它拿一个字符串去和一个整数进行比较时,PHP 会尝试将字符串转换为数字。

弱类型转换规则:
如果一个字符串以数字开头,PHP 在进行数学比较或类型转换时,会截取开头的数字部分,忽略后面的非数字字符。

例如:

“1.php” 会被转换为整数 1
因为1到36被包含的概率最大所以我们的文件名为1.php
然后我们就可以开始构造payload

我们先创建一个名为“1.php”的文件,并且在文件内写上一个一句话木马执行后我们在打开一个原url+1.php网站,通过psot方式执行命令

这里通过1=system(‘ls’);命令列出当前目录的文件和子文件夹发现有一个flag36d.php
判断flag应该藏在这个文件下,我们尝试读取该文件内容
通过1=system(‘tac flag36d.php’);命令查看该文件下的内容

得到flag为:ctfshow{024752ba-1087-4064-9c44-36f4887f0aa9}

http://www.jsqmd.com/news/951977/

相关文章:

  • 为什么有些影视网站越用越顺手?一次实际体验后的分析
  • Codex中文网 | Codex CLI 中文指南
  • 一件卫衣的诞生:从纱线到成衣的全流程解析
  • MatAnyone:一键实现专业级视频抠图的终极解决方案
  • 086、医疗影像病灶检测:YOLO 在 X 光、CT 切片上的小样本与正负样本不均衡方案
  • 深度解析BestBlogs开源项目:基于GitHub Actions自动化构建个人技术博客与内容聚合平台的实战指南
  • 别再踩坑了!用VMProtect SDK 3.4为你的软件实现一机一码+时间锁(附完整注册机源码)
  • 2026年现阶段,四川优质水果基地如何选?这份深度指南为您解析 - 2026年企业资讯
  • AI如何重塑秋冬服装赛道?实现降本增效新突破
  • 深圳配眼镜推荐指南:3 家硬核之选,少花冤枉钱还能 get 专业配镜 - 配眼镜新资讯
  • 终极指南:用开源神器TCC-G15彻底解决Dell G15散热烦恼
  • Logisim-evolution数字电路设计:从零开始到FPGA实现的完整指南
  • POP3协议抓包实战:从Wireshark过滤器技巧到常见认证失败排查
  • Aegisub字幕编辑高效解决方案:4大使用场景的完整技术指南
  • 085、安防监控行人属性检测:YOLO + 多属性分类 Head 的联合设计
  • 微信小程序二维码生成终极指南:weapp-qrcode高效解决方案
  • 3分钟掌握Windows窗口置顶技巧:告别频繁切换,工作效率提升50%
  • 2026年新消息:洞察国内扭王字块钢模市场格局与核心服务商推荐 - 2026年企业资讯
  • 如何3步制作专业LRC歌词:零基础入门完整指南
  • 终极指南:3分钟用BetterNCM Installer让网易云音乐焕然一新
  • Transformers 3.x 用户注意:本地加载bert-base-chinese模型,这几个版本兼容性坑别踩
  • 2026岳阳市权威认证贵金属回收 TOP5+黄金回收白银回收铂金回收门店地址电话推荐
  • 夹克制作全流程科普:工艺标准、自动化改造与设备科学选型
  • 084、自动驾驶行人车辆检测:多类别、多尺度、实时性的三角平衡方案
  • 测绘日常:ArcGIS 字段计算器实现固定前缀 + 10 位补零 BSM 自动编号
  • 智能对账系统选型避坑清单(2024最新实测数据版):87%企业踩中的AI集成断点全曝光
  • 5分钟终极指南:如何用Deceive实现Riot游戏隐身模式,专注游戏不被干扰
  • VTJ.PRO 双版本升级:构建企业级 AI 低代码协同开发新范式
  • NVIDIA Profile Inspector深度解析:显卡性能调优实战指南
  • 088、文字检测 YOLO 风格:用 YOLO 做场景文字检测替代 DBNet 的实验