Bugku 聪明的php

进入环境发现: pass a parameter and maybe the flag file’s filename is random 😆
意思是传递一个参数
所以我们get传参试试
在这里插入图片描述

进行代码审计: 发现smarty是个模板,测试一下是不是模板注入
所以 我们要了解一下smarty模板注入
在这里插入图片描述

然后发现过滤了很多函数,但是passthru没有被过滤
passthru()只调用命令,不返回任何结果,但把命令的运行结果原样地直接输出到标准输出设备上。所以passthru()函数经常用来调用象pbmplus(Unix下的一个处理图片的工具,输出二进制的原始图片的流)这样的程序。同样它也可以得到命令执行的状态码。
所以构造payload:{if passthru (‘ls’)}{/if}
在这里插入图片描述

再构造payload:{if passthru (‘ls -al /’)}{/if}
得到 start.sh
发现cat被过滤了 所以用tac
所以构造payload:{if passthru (‘tac/star.sh’)}{/if}
然后 {{passthru(‘more /*’)}}
得到flag
希望这篇文章能够帮到你!

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

M1kael

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值