0

0

Java面试之MyBatis中#{}和${}的区别

畫卷琴夢

畫卷琴夢

发布时间:2026-03-03 11:05:49

|

266人浏览过

|

来源于php中文网

原创

{}能防sql注入因其触发preparedstatement预编译,参数安全绑定;${}是字符串拼接,直接替换导致注入。仅当动态sql结构(如表名、排序字段)必须用${},须白名单校验或正则过滤。

java面试之mybatis中#{}和${}的区别

为什么#{}能防SQL注入而${}不能

根本原因在于 MyBatis 对两者的处理时机和方式完全不同:#{} 触发预编译(PreparedStatement),参数被当作占位符传入,数据库驱动自动做类型转换和转义;${} 是纯字符串替换,MyBatis 在 SQL 解析阶段就直接把变量值拼进 SQL 字符串里,不经过 JDBC 预编译流程。

比如传入用户名 "admin' OR '1'='1"

  • WHERE username = #{username} → 最终执行的是 WHERE username = ?,参数以安全方式绑定,不会改变 SQL 结构
  • WHERE username = '${username}' → 直接变成 WHERE username = 'admin' OR '1'='1',语句逻辑已被篡改

什么场景必须用${},以及怎么降低风险

${} 唯一合理用途是动态拼接 **SQL 结构部分**,比如表名、字段名、ORDER BY 子句、UNION 查询等——这些无法用 #{} 替代,因为 PreparedStatement 不允许对表名或关键字做参数化。

使用时必须严格校验输入,常见做法:

立即学习Java免费学习笔记(深入)”;

  • 只接受白名单枚举值,例如排序字段限定为 "id""create_time""status"
  • 用正则过滤:仅允许字母、数字、下划线,且长度限制在 32 字以内
  • 避免从用户请求中直接取值,优先通过接口参数映射到内部枚举或配置项

错误示例:

SELECT * FROM ${tableName} WHERE id = #{id}
—— 若 tableName 来自 HTTP 参数且未校验,可导致库表遍历攻击。

PHP轻论坛
PHP轻论坛

简介PHP轻论坛是一个简单易用的PHP论坛程序,适合小型社区和个人网站使用。v3.0版本是完全重构的版本,解决了之前版本中的所有已知问题,特别是MySQL保留字冲突问题。主要特点• 简单易用:简洁的界面,易于安装和使用• 响应式设计:适配各种设备,包括手机和平板• 安全可靠:避免使用MySQL保留字,防止SQL注入• 功能完善:支持分类、主题、回复、用户管理等基本功能• 易于扩展:模块化设计,便于

下载

ORDER BY 中用${}的典型写法与陷阱

这是最常踩坑的地方。很多人写成:ORDER BY ${sortField} ${sortOrder},但若 sortOrder 是用户传的 "ASC; DROP TABLE user;",就可能触发多语句执行(取决于数据库是否开启 allowMultiQueries)。

安全做法是分别约束两个变量:

  • sortField:匹配 ^[a-zA-Z_][a-zA-Z0-9_]{0,31}$
  • sortOrder:只允许 "ASC""DESC"(建议转大写后比对)

推荐写法:

<if test="sortField != null and sortField != ''">
  ORDER BY ${sortField}
  <choose>
    <when test="sortOrder == 'DESC'">DESC</when>
    <otherwise>ASC</otherwise>
  </choose>
</if>

性能与日志表现差异

虽然不影响功能,但会影响排查效率:#{} 在 MyBatis 日志中显示为带问号的 SQL(如 SELECT * FROM user WHERE id = ?),真实参数单独打印;${} 则直接显示拼接后的完整 SQL(如 SELECT * FROM user_log WHERE type = 'login')。

这意味着:

  • ${} 时,如果 SQL 报错,你看到的就是最终执行语句,容易定位问题
  • 但日志里也暴露了原始参数值,敏感字段(如手机号、身份证)可能泄露
  • #{} 日志更“干净”,但调试时需对照参数日志一起看

别为了省事把所有地方都换成 ${}——看似方便,实则埋下注入和合规隐患。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1090

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

339

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

380

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1988

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

379

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1540

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

438

2024.04.29

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

3

2026.03.03

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

相关下载

更多

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.1万人学习

C# 教程
C# 教程

共94课时 | 10.6万人学习

Java 教程
Java 教程

共578课时 | 76.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号