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后这一行就已经结束了,他会直接把输出结果输出到屏幕,后面的重定向限制根本管不到第一行的输出

相关推荐
kyriewen2 小时前
老板逼我上AI,我偷偷在浏览器里跑LLaMA,省下20万API费
前端·react.js·llm
Beginner x_u2 小时前
前端八股整理(手写 02)|数组转树、数组扁平化、随机打乱一个数组
前端·数组·数组转树·数组扁平化
KaMeidebaby2 小时前
卡梅德生物技术快报|禽类成纤维细胞 FISH 实验:鸟类性别染色体基因定位技术实现与数据验证
前端·数据库·其他·百度·新浪微博
没什么本事2 小时前
关于C# panel 添加lable问题 -- 明确X和Y 位置错误
android·java·c#
天若有情6732 小时前
前端高阶性能优化:跳出传统懒加载与预加载,基于用户行为做轻量预判加载
前端·性能优化
小小小小宇2 小时前
前端转后端:SQL 是什么
前端
张元清3 小时前
React Observer Hooks:7 种监听 DOM 而不写样板代码的方式
前端·javascript·面试
广州华水科技3 小时前
单北斗GNSS变形监测是什么?主要有怎样的应用与优势?
前端
卷帘依旧3 小时前
【未完待续】React高频面试题
前端