news 2026/1/7 16:11:11

【038-安全开发篇】JavaEE应用SpringBoot框架MyBatis注入Thymeleaf模版注入

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【038-安全开发篇】JavaEE应用SpringBoot框架MyBatis注入Thymeleaf模版注入

思维导图


知识点:

1、JavaEE-SpringBoot-WebAPP&路由
2、JavaEE-SpringBoot-Mybatis&注入
3、JavaEE-SpringBoot-Thymeleaf&SSTI

章节点

3、Java:
功能:数据库操作,文件操作,序列化数据,身份验证,框架开发,第三方库使用等.
框架库:MyBatis,SpringMVC,SpringBoot,Shiro,Log4j,FastJson等
技术:Servlet,Listen,Filter,Interceptor,JWT,AOP,反射机制待补充
安全:SQL注入,RCE执行,反序列化,脆弱验证,未授权访问,待补充
安全:原生开发安全,第三方框架安全,第三方库安全等,待补充

演示案例: SpringBoot-Web应用-路由响应 SpringBoot-数据库应用-Mybatis SpringBoot-模版引擎-Thymeleaf

Spring Boot是由Pivotal团队提供的一套开源框架,可以简化spring应用的创建及部署。它提供了丰富的Spring模块化支持,可以帮助开发者更轻松快捷地构建出企业级应用。Spring Boot通过自动配置功能,降低了复杂性,同时支持基于JVM的多种开源框架,可以缩短开发时间,使开发更加简单和高效。

SpringBoot-Web应用-路由响应

参考:https://springdoc.cn/spring-boot/
1、路由映射
@RequestMapping @GetMapping
2、参数传递
@RequestParam
3、数据响应
@RestController @Controller
@RestController注解相当于@ResponseBody+@Controller合在一起的作用。

@RestControllerpublicclassHelloController{//无参数访问响应@RequestMapping("/xiaodi")publicStringhello(){return"hello xiaodi";}//无参数指向GET方法访问响应@RequestMapping(value="/get",method=RequestMethod.GET)publicStringhelloGet(){return"hello get xiadi";}//有参数指向GET方法访问响应@RequestMapping(value="/getp",method=RequestMethod.GET)publicStringhellogetp(Stringname){return"hello get "+name;}//有参数指向POST方法访问响应@RequestMapping(value="/getpost",method=RequestMethod.POST)publicStringhelloGetParameters(Stringname){return"hello POST "+name;}}

SpringBoot-数据库应用-Mybatis

操作步骤:

0、数据库先创建需操作的数据

1、项目添加Mybatis&数据库驱动

-pom.xml

<dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>2.2.2</version></dependency><dependency><groupId>com.mysql</groupId><artifactId>mysql-connector-j</artifactId><scope>runtime</scope></dependency>

2、项目配置数据库连接信息
-application.yml

spring:datasource:url:jdbc:mysql://localhost:3306/demo01 username:root password:123456driver-class-name:com.mysql.cj.jdbc.Driver

3、创建User类用来操作数据库数据
-com.example.demo.entity.User

set get toString方法

4、创建Mapper动态接口代理类实现
-com.example.demo.mapper.UserMapper

@MapperpublicinterfaceUserMapper{@Select("select * from admin where id like '%${id}%'")//模糊查询,有安全危险publicList<User>findAll(Integerid);}

5、创建Controller实现Web访问调用
-com.example.demo.controller.UserController

@RestControllerpublicclassUserController{@AutowiredprivateUserMapperuserMapper;@RequestMapping(value="/getdata",method=RequestMethod.GET)//@ResponseBodypublicList<User>getdata(Integerid){List<User>all=userMapper.findAll(id);System.out.println(all);returnall;}}

可以在csdn搜索mybatis中SQL注入的文章,虽然有这种漏洞的可能性小,但是还是有可能

SpringBoot-模版引擎-Thymeleaf

  • 不安全的模版版本
    日常开发中:语言切换页面,主题更换等传参导致的SSTI注入安全问题(只有3.0.0到3.0.11版本有,后面就被修复了)
    漏洞参考:https://mp.weixin.qq.com/s/NueP4ohS2vSeRCdx4A7yOg

配置application.properties指向模版页面
spring.thymeleaf.prefix=classpath:/templates/
spring.thymeleaf.suffix=.html

@RequestMapping(value="/")publicStringindex(Modelmodel){model.addAttribute("data","hello xiaodi");return"index";}@GetMapping("/path")publicStringthymeleaf(Stringlang){returnlang;}<?xml version="1.0"encoding="UTF-8"?><project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>org.springframework</groupId><artifactId>java-spring-thymeleaf</artifactId><version>1.0</version><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><!--latest--><version>2.2.0.RELEASE</version></parent><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-thymeleaf</artifactId></dependency></dependencies><properties><java.version>1.8</java.version></properties><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build></project>
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/5 21:00:01

Langchain-Chatchat本地部署完整指南

本地化大模型落地实战&#xff1a;手把手构建安全可控的私有知识库问答系统 在企业级 AI 应用日益普及的今天&#xff0c;一个核心矛盾逐渐浮现&#xff1a;如何让强大的大语言模型&#xff08;LLM&#xff09;既能理解专业领域的私有知识&#xff0c;又能确保敏感数据不出内网…

作者头像 李华
网站建设 2026/1/4 13:15:57

场景化曝光:南宁出租车广告与GEO优化的协同密码

营销的核心是精准触达场景&#xff0c;南宁GEO优化与出租车广告的协同&#xff0c;正是围绕场景化曝光展开。五一卫浴通过二者联动&#xff0c;让品牌信息在用户消费决策的关键场景精准出现&#xff0c;实现曝光到转化的高效衔接。三大核心场景构建协同链路&#xff1a;交通枢纽…

作者头像 李华
网站建设 2026/1/6 5:38:48

卫星遥感数据核心参数解析:空间分辨率与时间分辨率

卫星遥感数据的空间分辨率和时间分辨率是衡量遥感数据实用性的两个核心指标&#xff0c;前者决定“看得多清”&#xff0c;后者决定“看得多勤”。【空间分辨率】卫星遥感数据的空间分辨率指的是遥感图像能够详细区分的最小地面单元的尺寸&#xff0c;也就是图像上的每个像元&a…

作者头像 李华
网站建设 2026/1/5 4:23:25

ComfyUI API使用指南:高效稳定的绘图接口

ComfyUI API 使用指南&#xff1a;构建高效稳定的 AI 绘图系统 在当今 AI 图像生成的应用场景中&#xff0c;越来越多的开发者不再满足于“点几下按钮出图”的简单操作。当需要将文生图能力集成到企业级产品、自动化平台或高并发服务时&#xff0c;传统 WebUI 的局限性立刻暴露…

作者头像 李华
网站建设 2026/1/3 19:07:35

Dify平台如何整合外部API扩展AI能力?

Dify平台如何整合外部API扩展AI能力&#xff1f; 在企业纷纷拥抱大模型的今天&#xff0c;一个现实问题摆在面前&#xff1a;如何让AI不只是“能说会道”&#xff0c;还能真正“动手办事”&#xff1f;很多团队尝试基于LLM搭建智能客服或知识助手&#xff0c;但很快发现&#x…

作者头像 李华
网站建设 2026/1/5 4:13:43

FLUX.1-ControlNet统一模型Pro 2.0发布

FLUX.1-ControlNet统一模型Pro 2.0发布 在生成式AI快速演进的今天&#xff0c;图像生成不再只是“输入文字、输出画面”的简单过程。越来越多的应用场景要求模型具备精确的空间控制能力——比如让角色摆出特定姿势、复现建筑草图的轮廓结构&#xff0c;或根据深度信息构建逼真…

作者头像 李华