ctf show web 入门46

这道题目是上一题的升级版,过滤条件变得更加苛刻了。我们来分析一下新增的限制以及应对方案。

  1. 代码审计与变化
    相比之前,正则过滤 preg_match 新增了以下内容:
    0-9:禁止使用任何数字。这意味着 IFS9 这种绕过方式失效了。
    \:禁止使用美元符号 。这意味着 ${IFS} 变量绕过空格的方式失效了。
    *:禁止使用通配符 。这意味着 fl 这种模糊匹配失效了。
    依然存在的限制:
    禁止分号 ;、关键词 cat、flag 以及 空格。
    末尾依然有 >/dev/null 2>&1 屏蔽回显。

既然数字、$ 和 * 都被封死了,我们需要寻找更原始的 Shell 特性。

A. 绕过空格 (禁止 $ 和数字)

由于不能用 ${IFS},我们可以使用以下方式:

<:输入重定向(最推荐)。

<>:读写重定向。

%09:URL 编码的 Tab 键。

B. 绕过关键词 flag (禁止 *)

由于不能使用 *,我们可以使用 ?。? 在 Linux Shell 中代表匹配任意单个字符。

flag.php 可以写成 fla?.php 或 fl??.php。

C. 绕过关键词 cat

继续使用替代命令:

tac, nl, more, less, head, tail, sort, uniq 等。

D. 截断重定向 >/dev/null

由于分号 ; 被过滤,依然使用:

|| (逻辑或)

%0a (换行符)

第一步:列目录

首先要看看文件名(虽然不能用数字,但 ls 不需要参数):

?c=ls||

或者

?c=ls%0a

第二步读取flag

构造的payload为:

?c=tac%09fla?.php%0a

或者:?c=tac%09fla?.php||

  1. 为什么限制数字,但 %0a %09 却能成功?
    这是一个关于解析顺序的误解。
    核心原理:URL 解码发生在正则检查之前
    在 Web 服务器(如 Apache/Nginx)接收到你的请求后,PHP 会在脚本运行之前自动对 GET/POST 参数进行 URL 解码。
    你的操作:你在浏览器地址栏输入 ?c=ls%0a。
    服务器处理:PHP 收到请求,立刻将 %0a 解码为真正的 换行符(Hex: 0x0A)。
    变量赋值:此时,变量 c 的内容实际上是 ls 后面跟着一个不可见的"回车换行"。 正则检查:preg_match("/\[0-9\]/", c) 检查的是解码后的字符。
    %0a 在解码后是一个控制字符(换行),它不是字符 0 或 9。
    正则匹配的是字面上的数字字符(ASCII 48-57),而换行符的 ASCII 码是 10。
    结论:%0a 只是换行符在传输过程中的"皮囊"。一旦进入 PHP 内部,它就变成了换行符,不再包含数字 0。
  2. 为什么 || 可以绕过重定向限制?
    要理解这个,需要先看清楚题目中 system 拼接后的完整命令结构。
    命令拼接的真相
    题目代码:system($c." >/dev/null 2>&1");
    如果你传入 c=ls||,最终在服务器终端执行的命令是:
    ls || >/dev/null 2>&1
    Shell 的逻辑运算符原理
    在 Linux Shell 中,|| 是一个**逻辑或(OR)**运算符,它遵循"短路逻辑":
    命令A || 命令B:只有当 命令A 执行失败(返回非零值)时,才会执行 命令B。
    执行命令 A:首先执行 ls。
    判断结果:ls 成功执行(找到了文件),返回状态码为 0(代表成功)。
    短路效应:因为 命令A 已经成功了,根据 OR 的逻辑,整个表达式已经成立,Shell 会直接跳过后面的 命令B。
    结果:后面的 >/dev/null 2>&1(也就是负责把结果丢进黑洞的命令)被忽略了。ls 的输出直接流向了标准输出,最后被 PHP 捕获并显示在网页上。
相关推荐
铁皮饭盒23 分钟前
Bun执行python代码
前端·javascript·后端
hunterandroid1 小时前
Service 与前台服务:让任务在后台持续运行
前端
米饭同学i1 小时前
深扒 LobsterAI 官网前端动效实现方案:从交互细节到代码实践
前端
rocpp1 小时前
Android 多语言切换实战:从 Context 到 Android 13 应用语言适配
android·kotlin
前端啊1 小时前
告别 el-table 打印难题,vue3-print-el-table 来了!
前端·vue.js
JarvanMo1 小时前
AI时代跨平台还有必要吗?
前端
Patrick_Wilson1 小时前
幂等到底是什么?从前端视角讲透 SQL、HTTP 与 POST 接口的幂等设计
前端·后端·架构
凌览1 小时前
一人公司别再上 Jenkins,真不值
前端·后端
oil欧哟1 小时前
Codex 最佳实践(超级长文):先搞懂 AI,再用好 AI
前端·人工智能·后端
小小小小宇1 小时前
前端渲染方式
前端