ctfshow web入门114

这是一道非常典型的 PHP 伪协议绕过(LFI/文件包含) 类型的 CTF 题目。代码的核心目的是让你读取到服务器上的某个文件,但它设置了严格的过滤。

php 复制代码
if(!is_file($file)){
    highlight_file(filter($file));
}else{
    echo "hacker!";
}

逻辑反转: 注意这里的 !(取反)。代码要求 is_file($file) 必须返回 false 才能进入文件读取的分支

含义: 如果你直接传入一个真实存在的文件路径(例如 file=flag.php),is_file() 会返回 true,取反后变成 false,直接触发 echo "hacker!";

突破思路: 我们需要传入一个既能让 is_file() (检查给定路径是否为一个常规文件)认为是目录或不存在的路径,但又能被 highlight_file() 正常解析并读取的特殊字符串

php 复制代码
if(preg_match('/compress|root|zip|convert|\.\.\/|http|https|data|data|rot13|base64|string/i', $file)){
    die('hacker!');
}

并且对输入的内容进行正则过滤

这里php://filter过滤器有部分被限制但是在旧版本或特定环境的 PHP 中,有些过滤器不需要显式写 convert.,或者可以用特殊组合

所以我们尝试构造payload:?file=php://filter/resource=./flag.php

  1. 为什么能成功绕过 is_file() ?
    代码中的第一道关卡是:
php 复制代码
if(!is_file($file)){ // 必须让 is_file 返回 false 才能进去
    highlight_file(filter($file));
}

在 PHP 中,is_file() 是用来检查一个本地常规文件是否存在的函数。

当你传入 $file = "php://filter/resource=./flag.php" 时:

is_file() 无法直接识别 php:// 这种内存伪协议流为一个普通的本地磁盘文件。

对于这种流或伪协议路径,is_file() 拿不到标准的操作系统文件状态,因此会直接返回 false。

!false 变成了 true,成功顺理成章地进入了 if 分支内部

  1. 为什么 highlight_file() 依然能读到文件?
    进入分支后,代码执行:
php 复制代码
highlight_file(filter($file));

虽然 is_file() 不认伪协议,但 PHP 的文件包含和读取函数(如 highlight_file()、include、file_get_contents())却原生支持 PHP 伪协议包装器(Wrappers)。

当 highlight_file() 接收到 php://filter/resource=./flag.php 时,PHP 底层会这样处理:

解析协议:识别出 php://filter 协议,知道这是一个过滤器流。

定位资源:看到 resource=./flag.php,PHP 包装器会在底层把它解析为当前目录下的 flag.php 文件。

读取并高亮:尽管没有使用 base64 等编码过滤器,这个协议的本质依然是"去读取 resource 指定的文件"。所以它会直接把 flag.php 的源码读取出来,并通过 highlight_file() 以高亮文本的形式渲染在屏幕上

相关推荐
黄林晴1 小时前
离谱!Android 17藏神仙功能,手机录屏叠加真人出镜
android
晓得迷路了1 小时前
栗子前端技术周刊第 133 期 - Angular v22、React 编译器 Rust 版、pnpm 11.5...
前端·javascript·css
朱涛的自习室1 小时前
Harness 还没学会,又来了个 Loop Engineering ?
android·人工智能·github
十月的皮皮1 小时前
C语言学习笔记20260614-数组奇偶数调整3种方法
c语言·笔记·学习
一个被程序员耽误的厨师1 小时前
02-架构篇-前端怎么反客为主把AI编排权拿回到自己手里
前端·人工智能·架构
怪我冷i1 小时前
人工智能的数学基础——学习笔记
人工智能·笔记·学习
羊羊小栈1 小时前
基于混合检索RAG的食品生产质量问答系统(BGE_BM25_大语言模型)
前端·人工智能·语言模型·自然语言处理·毕业设计·大作业
烤代码的吐司君1 小时前
Redis 服务配置与使用
前端·bootstrap·html
之歆2 小时前
Ajax 基础技术深度解析:XHR 从入门到跨域
前端·ajax·okhttp