ctf show web 入门42

打开靶场发现代码接收一个GET参数$c,并且将其传递给system()函数执行系统命令。但是在命令末尾强行拼接了一个>/dev/null 2>&1

/dev/null:将标准输出重定向到"黑洞",即你看不到命令执行的结果

2>&1:将标准错误也重定向到标准输出,导致也看不到命令执行结果

所以无论输入什么内容,页面都不会直接回显

faxain

我们可以尝试使用换行符%0a强制换行,让重定向的内容在下一行不再影响上一行的内容

我们先尝试查看当前目录下有什么文件所以构造的payload为:?c=ls%0a

发现有flag.php文件

所以我们尝试查看flag.php中的内容

payload为:?c=cat flag.php%0A

查看源代码得到flag

%0a之所以可以成功是因为在Linux终端中,换行符等同于按下回车键当代码执行 system(c." \>/dev/null 2\>\&1"); 时,如果你的 c 是 ls%0a,在系统底层执行的命令实际上变成了:

cat flag.php

dev/null2>&1

所以当执行cat flag.php后这一行就已经结束了,他会直接把输出结果输出到屏幕,后面的重定向限制根本管不到第一行的输出

相关推荐
徐小夕13 小时前
万字拆解 JitWord:企业级实时协同文档底层架构 + 大模型 AI 融合完整实践
前端·vue.js·github
一份执念13 小时前
uni-app 小程序分包限制处理与主包体积优化实战
前端·微信小程序
MariaH13 小时前
初识MySQL
前端
陳陈陳13 小时前
从Token到Embedding:一篇文章搞懂大模型的「文字数学变形记」
前端·javascript·ai编程
十有八七13 小时前
AI时代的置身X内
前端·人工智能
橘子星14 小时前
LLM 无状态架构实践:从原理到代码落地
前端·javascript·人工智能
LiuMingXin14 小时前
意图与代码之间:AI编程范式全景解读
前端·后端·面试
壹方秘境14 小时前
ApiCatcher支持抓包HTTP传输大文件的实现原理分享
前端·后端·客户端
一份执念15 小时前
uni-app项目 (vue+vite + uni-UI)中引入umd格式JS文件,微信小程序中导入报错处理方案
前端·uni-app·echarts
ClouGence15 小时前
2026 年自动化测试工具选型指南:8 款主流工具对比
前端·测试