攻防世界-web-easytornado

题目描述:Tornado 框架。打开链接是一个简单的界面

1. 思路分析

看到有个/flag.txt,我们点击进去看下

发现传入了两个参数,一个是filename,还有一个是filehash

看到里面的内容,提示我们真正的flag在 /fllllllllllllag中

因此,读取到 /fllllllllllllag就可以获取到真正的flag了,但是我们现在只知道文件名,并不知道对应的hash值,那么无法简单的通过请求进行处理

如何获取对应文件的hash值呢,看下其它两个文件

这里面提到的渲染还有计算hash值的方法,这里要如何利用呢?

由于对Tornado 框架了解较少,因此这里还是参考了网上资料才知道了漏洞原理。如果对该框架有一定了解的同学在看到上面的线索后应该很容易就能解出来了。该漏洞原理涉及到Tornado 框架本身 :

Tornado render是python中的一个渲染函数,也就是一种模板,如果用户对渲染的内容可控的话,那么可以通过render执行相应的代码,该框架中存在一些重要的配置对象可以被快速访问到,比如:handler.settings(参考:python SSTI tornado render模板注入_render tornado_multi4的博客-CSDN博客

ok。到了这里,题目就比较清晰了:

1.1 通过模板注入获取到关键信息cookie_secret

1.2 算出文件的hash值

1.3 获取文件内容

2. 解题过程

2.1 利用模板注入获取到cookie_secret

http://61.147.171.105:49529/error?msg={{handler.settings}}

我们获取到cookie_secret为64a44808-f4db-408c-8d56-b2b6adf380fa

2.2 计算 /fllllllllllllag 的文件hash值(这里计算的时候要用echo -n)

2.3 计算出文件hash值之后,然后传入filename和filehash获取文件内容即可

获取到flag为flag{3f39aea39db345769397ae895edb9c70}

总结: 这道题提示很清晰,但是需要一定的背景知识,关键点在于利用Tornado 框架进行模板注入获取关键信息cookie_secret,获取到之后就很容易解出来了

相关推荐
烷烯1 小时前
终端安全检测和防御技术
网络·安全
NewCarRen2 小时前
自动驾驶中安全相关机器学习功能的可靠性定义方法
安全·机器学习·自动驾驶
Yasmine 元素检测2 小时前
EN 62368消费电子、信息技术设备和办公设备安全要求标准
安全·电池·电子电气·ce认证·检测报告·red指令·lvd指令
Bruce_Liuxiaowei2 小时前
PHP伪协议详解:网络安全中的利用与防御
网络·web安全·php
꒰ঌ 安卓开发໒꒱2 小时前
SQL Server安全删除数据并释放空间的技术方案
数据库·安全·oracle
huluang3 小时前
中国网络安全处罚综合研究报告(2020-2025)
网络·安全·web安全
厦门辰迈智慧科技有限公司3 小时前
现代化水库运行管理矩阵建设的要点
运维·网络·物联网·线性代数·安全·矩阵·监测
天翼云开发者社区3 小时前
解码芯安全,天翼云红盾实验室筑牢“芯”防线!
安全
蚰蜒螟4 小时前
JVM安全点轮询汇编函数解析
汇编·jvm·安全
开发者如是说5 小时前
[中英双语] 如何防止你的 Android 应用被破解
android·安全