【网络安全 | CTF】攻防世界护网杯 2018 easy_tornado

本文介绍了Tornado框架的一个文件读取漏洞,通过os.path.abspath函数的处理,可以读取到不在指定目录下的文件。在攻防世界护网杯2018的CTF挑战中,利用此漏洞结合md5加密和cookie_secret,通过错误消息的msg漏洞及tornado的render功能执行命令,最终获取flag。

文章目录

Tornado

题目描述:tornado框架

Tornado全称Tornado Web Server,是一个用Python语言写成的Web服务器兼Web应用框架

简单说一下其框架漏洞的利用:

传入某文件的路径为“/Users/python/tornado-file-read/static/”

经过python中os.path.abspath函数处理

变成了“/Users/python/tornado-file-read/static”

所以:

如果有一个文件是“/Users/python/tornado-file-read/static.db”,

或一个目录是“/Users/python/tornado-file-read/static_private/”,

它们均以“/Users/python/tornado-file-read/static”开头

虽然这些文件并不在static这个目录下,但我们仍然可以通过/Users/python/tornado-file-read/static读取到它们

综上所述,os.path.abspath函数会造成一个文件读取漏洞,使我们读取到了本不应该被读取的某些文件。

接着我们看题目:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

秋说

感谢打赏

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

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

打赏作者

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

抵扣说明:

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

余额充值