buuctf_练[CSCCTF 2019 Qual]FlaskLight

[CSCCTF 2019 Qual]FlaskLight

文章目录

掌握知识

内置函数的过滤,globals变量的过滤,调用内部变量或函数的OS函数进行命令执行

解题思路

  1. 打开题目链接,很明显看标题和内容是flask模块的ssti模板注入了,查看源码,发现了传参的参数和请求方法
  1. 先测试一下{``{7*7}},正常返回49,证明存在ssti模板注入
  1. 直接使用内置函数url_for调用其内部的OS函数来进行命令执行,但发现页面报错500,看来多半是有过滤了,直接执行url_for也报错,证明过滤了url_for,测试config成功返回内容
  1. 尝试调用config的内部OS命令,但依旧报错,还有过滤,再次测试发现是globals被过滤了
  1. 使用命令拼接,将globals分成两半拼接一起就能绕过过滤了['__glo'+'bals__'],只不过必须使用[]的字典键值访问的形式,不能用.的形式了
  1. 查看根目录发现了flag文件,但是cat返回为空,以为命令被过滤了,后面才察觉原来是个目录,cd到文件下,查看到了flagapp.py源码,拿下flag

关键paylaod

复制代码
{{config.__class__.__init__['__glo'+'bals__']['os'].popen('ls').read()}}
相关推荐
曾阿伦13 小时前
Python 时间格式化指南
python
luanma15098013 小时前
Laravel vs ThinkPHP:框架选择终极指南
php·laravel
The_Ticker13 小时前
日股实时行情接口使用指南
java·经验分享·笔记·python·算法·区块链
试试勇气13 小时前
Linux学习笔记(十九)--生产消费模型与线程安全
java·笔记·学习
m0_5603964713 小时前
用Python创建一个Discord聊天机器人
jvm·数据库·python
StackNoOverflow13 小时前
Spring 纯注解配置 + Spring Boot 入门核心笔记
spring boot·笔记·spring
m0_5698814713 小时前
使用Flask快速搭建轻量级Web应用
jvm·数据库·python
2401_8732046513 小时前
用Pandas处理时间序列数据(Time Series)
jvm·数据库·python
2301_7765087213 小时前
定时任务专家:Python Schedule库使用指南
jvm·数据库·python
qq_3896001313 小时前
pads-logic 学习笔记
笔记·嵌入式硬件·学习·硬件工程·pcb工艺