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

【Java后端】MyBatis 与 MyBatis-Plus 如何防止 SQL 注入?从原理到实战

在日常开发中,SQL 注入是一种常见但危害巨大的安全漏洞。如果你正在使用 MyBatis 或 MyBatis-Plus 进行数据库操作,这篇文章将带你系统了解:这两个框架是如何防止 SQL 注入的,我们又该如何写出安全的代码。


什么是 SQL 注入?

SQL 注入(SQL Injection)是指攻击者通过输入恶意 SQL 语句,干扰原本正常的数据库查询,从而达到绕过登录、获取数据、甚至删除数据库的目的。

举个例子:

SELECT * FROM user WHERE name = 'admin' AND password = '123456' OR '1'='1'

如果我们将用户输入直接拼接到 SQL 中,攻击者就可能利用 OR '1'='1' 这样的语句,绕过身份验证。


MyBatis 如何防止 SQL 注入?

使用 #{} 占位符(参数绑定)

MyBatis 的推荐做法是:使用 #{} 进行参数绑定。这是最有效的 SQL 注入防范方式。

<select id="selectUserByName" resultType="User">SELECT * FROM user WHERE name = #{name}
</select>
  • #{name} 会被转换为 JDBC 的 PreparedStatement 参数,占位符 ?
  • 由 MyBatis 自动将变量安全注入,避免注入风险。

避免 ${} 动态拼接

<select id="selectUserByName" resultType="User">SELECT * FROM user WHERE name = '${name}'
</select>
  • ${} 会直接将用户输入拼接到 SQL 字符串中。
  • 攻击者可以输入 ' OR 1=1 -- 这样的语句,造成严重后果。

总结

  • 使用 #{}:安全
  • 避免使用 ${}:易受攻击

MyBatis-Plus 如何防止 SQL 注入?

MyBatis-Plus 是 MyBatis 的增强工具,大量简化了开发。它默认使用参数绑定机制,在大多数情况下天然具备防注入能力

条件构造器安全性

QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.eq("name", userName);
userMapper.selectList(wrapper);
  • .eq("name", userName) 会使用 PreparedStatement 自动绑定参数。
  • 比手写 SQL 更简洁也更安全。

apply 使用注意事项

有时候你可能需要执行一些复杂的 SQL 片段,比如使用 SQL 函数:

wrapper.apply("DATE_FORMAT(create_time,'%Y-%m-%d') = {0}", dateStr);
  • 使用 {0} 绑定参数,是安全的。
  • 直接拼接字符串不安全:
wrapper.apply("DATE_FORMAT(create_time,'%Y-%m-%d') = '" + dateStr + "'");

实战建议

  1. 优先使用 MyBatis-Plus 提供的 API,如 Wrapper、LambdaQueryWrapper
  2. MyBatis XML 中,禁止使用 ${},一律使用 #{}
  3. 自定义 SQL 时,确保参数使用绑定方式
  4. 开启 SQL 日志,排查拼接风险
  5. 可选:配合 SQL 审计工具做自动扫描

如果你觉得这篇文章对你有帮助,不妨点个赞

http://www.xdnf.cn/news/94627.html

相关文章:

  • Kotlin 协程在 LiveData 中的完美封装:CoroutineLiveData 全解
  • Spring Boot 项目:如何在 JAR 运行时读取外部配置文件
  • Ubuntu启动SMB(Samba)服务步骤
  • RocketMQ面试题:进阶部分
  • [LLaVA] Visual Instruction Tuning
  • MFC案例:使用键盘按键放大、缩小窗口图像的实验
  • 【Unity笔记】Unity 编辑器扩展:一键查找场景中组件引用关系(含完整源码)(组件引用查找工具实现笔记)
  • Kafka
  • Vmware安装centos7和Redis
  • KafkaSpark
  • git 将某次提交的某个文件提交到另一个分支
  • 基于CBOW模型的神经网络词向量转换原理与实践
  • SQL 多表查询:数据整合与分析的强大工具
  • sizeof和strlen的区别
  • URP-UGUI交互功能实现
  • NLP高频面试题(五十三)——LLM中激活函数详解
  • 【无人机】无人机光流模块Optical Flow设置(三),光流测距一体传感器的配置。凌启科技的光流测距一体模块的测试。
  • 珈和科技助力“农险提效200%”!“遥感+”技术创新融合省级示范项目荣登《湖北卫视》!
  • Javashop新零售电商系统:构建智能零售生态的终极解决方案
  • 【android bluetooth 框架分析 03】【Bta 层详解 1】【Bluetooth Application Laye 介绍】
  • 5.4.云原生与服务网格
  • 数据为基:机器学习中数值与分类数据的处理艺术及泛化实践
  • C++ 容器查找效率
  • Java基础:认识注解,模拟junit框架
  • 如何提升个人解决问题的能力?
  • Ethan独立开发产品日报 | 2025-04-22
  • CS 系列 USB3.0 工业面阵相机不同快门类型的作用及其区别
  • 从边缘到云端,如何通过时序数据库 TDengine 实现数据的全局洞
  • 神经网络相关内容
  • JavaScript 渲染内容爬取:Puppeteer 高级技巧与实践