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

ctf show web入门115

这是一道非常经典的 PHP 弱类型与特性绕过的 CTF 题目。核心目标是通过 ?num=xxx 传入一个参数,使得它能通过那一长串复杂的 if 条件判断,最终走到 echo $flag;。

我们把核心的判断条件列出来,需要同时满足以下 4个外部条件 和 1个内部条件:

if(is_numeric($num)// 1. 必须是一个数字或数字字符串and$num!=='36'// 2. 强类型比较,绝对不能等于字符串 '36'andtrim($num)!=='36'// 3. 去除首尾空格后,绝对不能等于字符串 '36'andfilter($num)=='36'// 4. 经过 filter() 函数过滤、替换后的结果,弱类型等于 '36'){if($num=='36'){// 5. 内部条件:$num 本身弱类型等于 '36'echo$flag;}}

关键函数 filter($num) 分析:
这个函数会把 $num 中的以下字符全部替换为 “1”:
0x (十六进制)
0
. (浮点数小数点)
e 或 E (科学计数法)

  • (正号)

核心突破口:PHP 的弱类型与空白字符
我们要让一个字符串既满足 is_numeric,又在弱类型比较(==)下等于 36,同时还不能直接是 ‘36’。

绕过思路一:利用空白字符
PHP 的 is_numeric() 和弱类型比较 == 在处理数字时,会忽略字符串开头的某些空白字符(例如空格 %20、制表符 %09、换行符 %0a、回车 %0d、水平制表符 %0b、换页符 %0c 等)。

但是,题目中有一个条件叫 trim($num) !== ‘36’。

trim() 会去除:空格、\t、\n、\r、\0、\x0B。

注意: trim() 不会去除换页符 \f(URL编码为 %0c)。

如果我们传入 %0c36:
is_numeric(“%0c36”) ->True (PHP 认为它是数字 36)
“%0c36” !== ‘36’ -> True (强类型不相等)
trim(“%0c36”) -> 结果依然是 “%0c36”,所以 !== ‘36’ -> True
filter(“%0c36”) -> 里面没有要替换的字符,结果是 “%0c36”。在 filter($num) == ‘36’ 时,由于是弱类型比较,%0c36" 会被转换为数字 36 -> True
内部条件 “%0c36” == ‘36’ -> True所以我们构造payload为:?num=%0c36

为什么空格 %20、制表符 %09、换行符 %0a、回车 %0d、水平制表符 %0b不能绕过限制

字符编码 (URL),对应的空白字符类型,trim() 是否会切除?
%20,普通空格 (Space),会,直接切除
%09,制表符 (Tab),会,直接切除
%0a,换行符 (Line feed),会,直接切除
%0d,回车符 (Carriage return),会,直接切除
%00,空字节 (NUL-byte),会,直接切除
%0b,垂直制表符 (Vertical tab),会,直接切除
%0c,换页符 (Form feed),不会切除!

因为在 PHP 的底层逻辑中,当它遇到像 %20(空格)、%09(制表符)、%0a(换行)这类标准空白字符开头+数字的字符串时,is_numeric() 和弱类型比较 == 会自动忽略开头的空白,直接把后面的 36 提取出来进行计算。

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

相关文章:

  • 下一代金融数据处理系统:实时订单簿重建技术深度解析
  • Java毕设选题推荐:基于 SpringBoot 的水果商品展示与交易管理系统的设计与实现 生鲜水果线上零售管理平台【附源码、mysql、文档、调试+代码讲解+全bao等】
  • 免费IDM激活脚本完整指南:一键解锁下载加速器
  • 深入解析dex2jar:从Dalvik字节码到Java字节码的专业转换引擎
  • 2026免费视频转MOV在线保姆级教程!无限制工具手把手教学,苹果Final Cut Pro直接导入 - 时时资讯
  • 3DGRUT实战指南:高效高斯粒子光线追踪与栅格化技术深度解析
  • 从写完就发到AI发布策略_CSDN_AI数字营销让内容分发变了什么
  • Java毕设选题推荐:基于 B/S 架构的调查问卷管理系统的设计与实现 基于 Spring Boot 的轻量化问卷采集系统的设计与实现【附源码、mysql、文档、调试+代码讲解+全bao等】
  • Nature 子刊观点:AI 检测让论文写作陷入两难
  • 2026免费音频转AC3在线保姆级教程!无限制工具手把手教学,杜比数字环绕声制作必备 - 时时资讯
  • 2026年怀化手表回收到底该怎么选?给你推荐五家靠谱的(2026年6月14日最新版) - 空空是也
  • 2026免费视频转WMV在线保姆级教程!无限制工具手把手教学,Windows老系统兼容神器 - 时时资讯
  • MPC7450处理器信号接口深度解析:L3缓存、中断与时钟配置实战
  • HackMyVM-Canto
  • 2026免费视频转WEBM在线保姆级教程!无限制工具手把手教学,HTML5现代网页最佳格式 - 时时资讯
  • 如何让Paperless-ngx说你的语言:从中文界面到多语言文档管理
  • 从直播小白到多平台达人:obs-multi-rtmp带你玩转同步直播
  • Deep-Live-Cam:3步实现实时AI换脸,开启移动端深度伪造新纪元
  • 微信社交关系管理神器:3分钟检测谁删了你,告别单向好友烦恼
  • shutil模块
  • 3步实现缠论自动分析:通达信免费插件实战指南
  • 后ChatGPT时代的杀手级应用:会使用工具的AI Agent产品预测
  • 2026免费音频转AMR在线保姆级教程!无限制工具手把手教学,老旧录音笔也能轻松播放 - 时时资讯
  • 如何构建互动桌面宠物:打造响应式Live2D动画系统
  • MPC7450缓存架构与MPX总线设计:从原理到工程实践
  • 2026免费视频转AVI在线保姆级教程!无限制工具手把手教学,老式影碟机/U盘即插即播 - 时时资讯
  • 5分钟快速上手ChatWiki:开源知识库系统的完整使用指南
  • 京东寄大件物流怎么收费?超全省钱攻略来了 - 快递物流资讯
  • 云计算学习中心第四次作业
  • 软件开发全链路效能提升实战指南