Mybatis like 查询 防止SQL注入方法相关原理和解决方法整理

来源:互联网 发布:java web 报表 开源 编辑:程序博客网 时间:2024/06/08 06:40

SQL注入:引自百度百科:

所谓SQL注入,就是通过把SQL命令插入到Web表单提交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令。具体来说,它是利用现有应用程序,将(恶意)的SQL命令注入到后台数据库引擎执行的能力,它可以通过在Web表单中输入(恶意)SQL语句得到一个存在安全漏洞的网站上的数据库,而不是按照设计者意图去执行SQL语句。[1]  比如先前的很多影视网站泄露VIP会员密码大多就是通过WEB表单递交查询字符暴出的,这类表单特别容易受到SQL注入式攻击

mybatis中的#和$的区别 :点击打开链接

 主题:ibatis中,关于$和#的微妙关系 点击打开链接

Mybatis3 防止SQL注入 点击打开链接


#{xxx},使用的是PreparedStatement,会有类型转换,所以比较安全;
${xxx},使用字符串拼接,可以SQL注入;
like查询不小心会有漏动,正确写法如下:
Mysql: select * from t_user where name like concat('%', #{name}, '%')  

0 0
原创粉丝点击