【转】mybatis如何防止sql注入

如题所述





mybatis框架作为一款半自动化的持久层框架,其sql语句都要我们自己来手动编写,这个时候当然需要防止sql注入。其实Mybatis的sql是一个具有“输入+输出”功能,类似于函数的结构,如下:

<select id=“getBlogById“ resultType=“Blog“ parameterType=”int”>
select id,title,author,content from blog where id=#{id}
</select>
这里,parameterType标示了输入的参数类型,resultType标示了输出的参数类型。回应上文,如果我们想防止sql注入,理所当然地要在输入参数上下功夫。上面代码中高亮部分即输入参数在sql中拼接的部分,传入参数后,打印出执行的sql语句,会看到sql是这样的:

selectid,title,author,contentfromblog where id = ?

不管输入什么参数,打印出的sql都是这样的。这是因为mybatis启用了预编译功能,在sql执行前,会先将上面的sql发送给数据库进行编译,执行时,直接使用编译好的sql,替换占位符“?”就可以了。因为sql注入只能对编译过程起作用,所以这样的方式就很好地避免了sql注入的问题。

mybatis是如何做到sql预编译的呢?其实在框架底层,是jdbc中的PreparedStatement类在起作用,PreparedStatement是我们很熟悉的Statement的子类,它的对象包含了编译好的sql语句。这种“准备好”的方式不仅能提高安全性,而且在多次执行一个sql时,能够提高效率,原因是sql已编译好,再次执行时无需再编译。

话说回来,是否我们使用mybatis就一定可以防止sql注入呢?当然不是,请看下面的代码:

<select id=“orderBlog“ resultType=“Blog“ parameterType=”map”>
select id,title,author,content from blog order by ${orderParam}
</select>
仔细观察,内联参数的格式由“#{xxx}”变为了${xxx}。如果我们给参数“orderParam”赋值为”id”,将sql打印出来,是这样的:

select id,title,author,content fromblog order by id

显然,这样是无法阻止sql注入的。在mybatis中,”${xxx}”这样格式的参数会直接参与sql编译,从而不能避免注入攻击。但涉及到动态表名和列名时,只能使用“${xxx}”这样的参数格式,所以,这样的参数需要我们在代码中手工进行处理来防止注入。

结论:在编写mybatis的映射语句时,尽量采用“#{xxx}”这样的格式。若不得不使用“${xxx}”这样的参数,要手工地做好过滤工作,来防止sql注入攻击。
【转】mybatis如何防止sql注入
标签:

温馨提示:内容为网友见解,仅供参考
无其他回答

mybatis如何防止sql注入
1. 使用预编译的SQL语句:MyBatis支持使用#{param}的方式传递参数,MyBatis会自动进行参数的预编译,防止SQL注入的风险。```xml SELECT * FROM user WHERE id = #{id} ```2. 参数校验和转义:在业务逻辑层或者控制层对参数进行校验,确保参数的合法性。同时,对于要插入到数据库中的参数,可以使...

#{}如何防止SQL注入的?它的底层原理是什么?
在MyBatis中,${}和#{}用于处理SQL查询参数。使用${}直接将参数值插入到SQL语句中,这可能导致SQL注入攻击。而#{}通过预编译方式,将参数值与SQL语句进行分离,有效防止了SQL注入。SQL注入问题:当使用${}时,参数值直接与SQL语句进行拼接,如果参数中包含特殊字符,如单引号或双引号,就可能导致SQL...

预编译如何避免SQL注入 Mybatis SQL预编译 注入
Mybatis利用PreparedStatement实现预编译功能,其中,#{}符号会自动处理为字段值,通过添加双引号进行转义,避免了SQL注入的风险。相比之下,${}符号则不会预编译,直接作为字符串拼接到SQL中,易导致注入问题。预编译功能的实现依赖于数据库的具体支持,并非所有数据库都具备。其主要目的有两点:提高性能和...

mybatis在传参时,为什么#能够有效的防止sql注入
因为在mybatis中,”${xxx}”这样格式的参数会直接参与sql编译,从而不能避免注入攻击。但涉及到动态表名和列名时,只能使用“${xxx}”这样的参数格式,所以,这样的参数需要程序开发者在代码中手工进行处理来防止注入。xxx# 代表xxx是属性值,map里面的key或者是你的pojo对象里面的属性, ibatis会自动在...

【转】mybatis如何防止sql注入
mybatis框架作为一款半自动化的持久层框架,其sql语句都要我们自己来手动编写,这个时候当然需要防止sql注入。其实Mybatis的sql是一个具有“输入+输出”功能,类似于函数的结构,如下: select id,title,author,content from blog where id=#{id}这里,parameterType标示了输入的参数类型,resultTy...

MyBatis如何防止SQL注入
不管输入什么参数,打印出的SQL都是这样的。这是因为MyBatis启用了预编译功能,在SQL执行前,会先将上面的SQL发送给数据库进行编译;执行时,直接使用编译好的SQL,替换占位符“?”就可以了。因为SQL注入只能对编译过程起作用,所以这样的方式就很好地避免了SQL注入的问题。【底层实现原理】MyBatis是如何...

MyBatis怎么防止SQL注入
mybatis框架作为一款半自动化的持久层框架,其sql语句都要我们自己来手动编写,这个时候当然需要防止sql注入。其实Mybatis的sql是一个具有“输入+输出”功能,类似于函数的结构,如下: select id,title,author,content from blog where id=#{id} 这里,parameterType标示了输入的参数类型,resultType标示了...

Mybatis-plus sql注入及防止sql注入详解
在使用分页的controller中,对传入的分页参数进行检查,判断是否有非法字符,防止SQL注入。例如,对于`ascs`与`descs`字段的非法字符检查,确保参数安全。如果参数中包含非法列名如`create_time aaaa`,则返回错误提示。实现Mybatis Plus自定义全局SQL注入策略,步骤如下:在mapper中定义业务方法。实现自己的...

Mybatis是如何实现防止SQL注入
这条语句是可以正常运行并且符合我们预期的。但是如果传入的参数变成‘‘ or 1=1,这时这条语句变成select * from user where id = ‘‘ or 1=1。让我们想一下这条语句的执行结果会是怎么?它会将我们用户表中所有的数据查询出来,显然这是一个大的错误。这就是SQL注入。Mybatis如何防止SQL注入在...

mybatis怎么防止sql注入
用#进行参数传递,不要用$,$容易引起参数注入,#会解析成字符串。

相似回答
大家正在搜