ctf show web 入门46

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

  1. 代码审计与变化
    相比之前,正则过滤 preg_match 新增了以下内容:

    0-9\]:禁止使用任何数字。这意味着 $IFS$9 这种绕过方式失效了。 \\$:禁止使用美元符号 $。这意味着 ${IFS} 变量绕过空格的方式失效了。 \*:禁止使用通配符 *。这意味着 fl* 这种模糊匹配失效了。 依然存在的限制: 禁止分号 ;、关键词 cat、flag 以及 空格。 末尾依然有 \>/dev/null 2\>\&1 屏蔽回显。 ![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/fbb6a5f43be84d31aa84f857c4c0dc6e.png)

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 捕获并显示在网页上。
相关推荐
栈溢出了1 小时前
GNN 学习笔记:edge_index 与 W 参数矩阵
人工智能·笔记·神经网络·学习
ooseabiscuit1 小时前
PHP与C++:Web与系统编程的终极对决
前端·c++·php
SEO_juper1 小时前
外贸独立站流量翻倍后的转化优化
大数据·前端·seo·geo·外贸独立站·谷歌优化·2026
九思十安1 小时前
HNU2026-计算机系统-笔记 7 浮点数
笔记
i学长的猫1 小时前
# Hermes + Web UI 本地 Docker 部署指南
前端·ui·docker
九思十安1 小时前
HNU2026-计算机系统-笔记 4 汇编初步
汇编·笔记
yanyu-yaya1 小时前
css篇之网格grid 学习
前端·css·学习
MandalaO_O1 小时前
Web 开发:计算机网络知识梳理
前端·网络·计算机网络
lyp90h1 小时前
Claude Code CLI System Prompt 完整分析
java·前端·prompt