ctf show web 入门32

这是一款典型的 PHP 代码审计与命令执行(RCE) 类型的 CTF 题目。代码的核心逻辑是接收一个 GET 参数 c,在经过正则过滤后,将其放入 eval() 函数中执行。

目标:绕过 preg_match 的正则限制,执行命令读取服务器上的 flag 文件。

正则过滤内容:

关键字:flag, system, php, cat, sort, shell, echo

特殊符号:. (点), (空格), ' (单引号), ` (反引号), ; (分号), ( (左括号), / (斜杠)

修饰符:/i 表示不区分大小写。

核心难点与突破口

这个正则表达式非常严格,过滤了括号 (,这意味着你无法直接调用任何 PHP 函数(如 system(), passthru() 等)。同时过滤了分号 ;,这意味着你只能执行一条语句,且不能用常规方式结尾。

突破点 A:PHP 伪协议与通配符

由于过滤了 flag 关键字,我们需要用通配符(如 ? 或 *)来匹配文件名。例如,flag.php 可以表示为 fla?。

突破点 B:绕过分号与括号

既然不能用 system(),我们需要寻找不需要括号也能触发命令执行的方法。

利用 PHP 的 include 包含:include 是一个语句而非函数,可以不加括号使用:include $_GET[1]。

利用标记闭合:PHP 脚本可以用 ?> 来代替最后一个分号。

所以我们尝试使用include配合数据流,可以尝试一个动态参数从而绕过原本对c的限制我们构造的payload如下:?c=includec的限制 我们构造的payload如下:?c=includec的限制我们构造的payload如下:?c=include_GET[1]?>&1=php://filter/read=convert.base64-encode/resource=flag.php

得到一串base64编码后的内容,打开base64解码的网站

得到flag

本题的核心指令includeGET[1]?>这部分是填入_GET[1]?>这部分是填入GET[1]?>这部分是填入c的内容,目的是为了绕过preg_match的正则限制

1.include(绕过括号限制)

原理:在PHP中,include属于语言结构,而不是普通函数

特性:调用它时不需要加括号正则表达式过滤了(,所以我们不能用system(),passthru()等函数

2.GET[1](注入参数)原理:正则过滤了flagphpcat等关键字,如果我们直接在_GET[1](注入参数) 原理:正则过滤了flag php cat 等关键字,如果我们直接在GET[1](注入参数)原理:正则过滤了flagphpcat等关键字,如果我们直接在c这里写这些词就会被拦截

技巧:我们在这里引入一个新参数1,正则只会检查变量c的内容,,不会检查c的内容,,不会检查c的内容,,不会检查_GET里的内容

3.?>(绕过分号限制)

原理:正则过滤了分号;,在PHP中,分号是语句结束的标志。

特性:PHP的闭合标签?>会隐藏一个分号的效果,通过它我们可以告诉服务器这行代码结束了,从而绕过对;的拦截

相关推荐
panyingdao1 小时前
水平渐变进度条实现笔记
笔记
码途漫谈1 小时前
Easy-Vibe高级开发篇阅读笔记(十三)——多平台开发之Android App 原生开发
android·人工智能·笔记·ai·开源·ai编程
羊群智妍2 小时前
2026 GEO监测工具全景:AI搜索优化从入门到进阶
笔记
skilllite作者2 小时前
GEO 是什么:从搜索引擎到「对话式答案」的信息可见性
java·前端·笔记·安全·搜索引擎·agentskills
今儿敲了吗2 小时前
链表篇(五)——链表中间结点
数据结构·笔记·算法·链表
YYYing.2 小时前
【C++项目之高并发内存池 (三)】万字解析CentralCache与PageCache的初步实现
c++·笔记·哈希算法·高并发·c/c++·内存池
容智信息3 小时前
不写SQL,不拉Excel:数据分析用“问”的
数据库·人工智能·笔记·数据分析·excel·知识图谱·知识库
05候补工程师3 小时前
【线性代数笔记】秩、线性相关性与等价向量组的核心逻辑总结
经验分享·笔记·线性代数·机器学习
van久3 小时前
Day24:JWT 权限验证中间件 + 认证授权全套实战(笔记 + 面试题 + 落地步骤)
笔记·中间件