【Java代码审计(2)】MyBatis XML 注入审计

代码背景:某公司使用 MyBatis 作为持久层框架,登录功能如下:

Java 接口代码:

复制代码
public interface UserMapper {
    User findByUsernameAndPassword(@Param("username") String username,
                                    @Param("password") String password);
}

XML 配置(UserMapper.xml)如下:

复制代码
<select id="findByUsernameAndPassword" parameterType="map" resultType="User">
    SELECT * FROM users 
    WHERE username = '${username}' 
      AND password = '${password}'
</select>

先来分析一下java接口代码
UserMapper是MyBatis约定俗称的,MyBatis数据的访问接口都叫xxxxUser说明这里是要操作User

复制代码
User findByUsernameAndPassword(...)

User:这是返回值类型,说明这个方法会返回一个 User 类型的 Java 对象。

复制代码
int add(int a, int b);        // 返回 int
String getName();             // 返回 String
void logout();                // 返回 void(表示没有返回值)
User findByUsername(...);     // 返回 User

findByUsernameAndPassword:方法名称。看名字就知道,它表示"根据用户名和密码查找用户"。

复制代码
@Param("username") String username,
@Param("password") String password

这是传入的两个参数

告诉 MyBatis:我这个 String username 参数,在 SQL 里要叫 username。

如果不添加@Param("username")

那么在编译成.class文件后,这个方法里面的参数会变成

复制代码
(String arg0, String arg1)

那么Mybatis就读不到你叫他username,password

现在再来分析XML文件

复制代码
<select id="findByUsernameAndPassword" parameterType="map" resultType="User">
  • <select id =xxxxx>要把这个 SQL 查询语句,绑定到 Java 接口里的 findByUsernameAndPassword() 方法上,等你调用这个方法的时候,我就执行这个 SQL,并把查到的数据返回回去。
  • parameterType="map" 表示传入的方法是表示方法传入的是 Map 类型(键值对)
  • resultType="User"查询结果将映射成 User 类型的 Java 对象

接下来就是sql语法了,这里需要关注
${}#{}

#{} 是安全的参数占位符(预编译/参数化)

${} 是直接字符串拼接(不安全,容易 SQL 注入)

但是如果必须使用${}时,就需要添加白名单

比方说:动态排序

如果写成
select * from users order by #{}

数据库就会报错 Unknown column '?'

因为数据库只会把参数化,而不会把结构参数化!

相关推荐
qcx231 小时前
【AI Agent实战】OpenClaw 安全加固完全指南:安全攻击手段与五步防护实践(2026最新)
人工智能·安全
一 乐3 小时前
电影院|基于springboot + vue电影院购票管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·电影院购票管理管理系统
恼书:-(空寄3 小时前
JVM GC 日志分析 + 常见 GC 场景 + 实战参数调优
java·jvm
消失的旧时光-19433 小时前
Spring Boot 实战(五):接口工程化升级(统一返回 + 异常处理 + 错误码体系 + 异常流转机制)
java·spring boot·后端·解耦
Micr0674 小时前
利用Werkzeug-Debug实现本地权限提升
python·web安全·网络安全
Chockmans4 小时前
春秋云境CVE-2021-34257
安全·web安全·网络安全·php·网络攻击模型·春秋云境·cve-2021-34257
杨凯凡4 小时前
【012】图与最短路径:了解即可
java·数据结构
比特森林探险记4 小时前
【无标题】
java·前端
椰猫子5 小时前
Javaweb(Filter、Listener、AJAX、JSON)
java·开发语言
朝新_5 小时前
【Spring AI 】核心知识体系梳理:从入门到实战
java·人工智能·spring