HFCTF2022 ezphp
文章目录
题目上去给了代码
<?php (empty($_GET["env"])) ? highlight_file(__FILE__) : putenv($_GET["env"]) && system('echo hfctf2022');?>
这个题目本来以为考点是p佬的文章,但是不是这样的。
p佬文章:我是如何利用环境变量注入执行任意命令
这个题目的考点是Nginx 在后端 Fastcgi 响应过大 或 请求正文 body 过大时会产生临时文件。如果打开一个进程打开了某个文件,某个文件就会出现在 /proc/PID/fd/ 目录下,我们可以通过重复发包so造成文件缓存,然后用LD_PRELOAD去加载我们这个动态链接库
当nginx接收来自fastcgi的响应时,若大小超过限定值不适合以内存的形式来存储的时候,一部分就会以临时文件的形式保存到磁盘上。
所以我们的exp.so需要加上一些无用数据让整个文件稍大。
具体可以参考hxp CTF 2021 跳跳糖社区
exp.c
#include <stdlib.h>
#include <stdio.h>
#include

本文介绍了一个名为HFCTF2022 ezphp的比赛题目,详细解析了如何通过利用Nginx和Fastcgi的特性,结合环境变量注入技巧,最终实现获取flag的过程。
最低0.47元/天 解锁文章
944

被折叠的 条评论
为什么被折叠?



