通过ibatis解决sql注入问题
程序员文章站
2024-03-31 17:40:58
于ibaits参数引用可以使用#和两种写法,其中#写法会采用预编译方式,将转义交给了数据库,不会出现注入问题;如果采用两种写法,其中#写法会采用预编译方式,将转义交给了数据...
于ibaits参数引用可以使用#和两种写法,其中#写法会采用预编译方式,将转义交给了数据库,不会出现注入问题;如果采用两种写法,其中#写法会采用预编译方式,将转义交给了数据库,不会出现注入问题;如果采用写法,则相当于拼接字符串,会出现注入问题。
例如,如果属性值为“' or '1'='1 ”
,采用#写法没有问题,采用写法就会有问题。对于语句,难免要使用写法就会有问题。对于like语句,难免要使用写法,
1. 对于oracle可以通过'%'||'#param#'||'%'避免;
2. 对于mysql可以通过concat('%',#param#,'%')避免;
3. mssql中通过'%'+#param#+'% 。
mysql: select * from t_user where name like concat('%',#name #,'%') oracle: select * from t_user where name like '%'||#name #||'%' sql server:select * from t_user where name like '%'+#name #+'%
总结
以上所述是小编给大家介绍的通过ibatis解决sql注入问题,希望对大家有所帮助
推荐阅读
-
通过ibatis解决sql注入问题
-
解决SQL Server的“此数据库没有有效所有者”问题
-
MySQL解决SQL注入的另类方法详解
-
解决@Autowired注入空指针问题(利用Bean的生命周期)
-
解决@Autowired注入空指针问题(利用Bean的生命周期)
-
Spring 依赖注入三种方式的实现,及循环依赖问题的解决(源码+XML配置)
-
解决通过this.class.getResource()得到的URL中乱码的问题及源码解析:
-
【oracle】初学jobs 博客分类: SQL学习问题解决 oraclejob
-
【oracle】初学jobs 博客分类: SQL学习问题解决 oraclejob
-
一个SQL错误:9003 博客分类: 问题解决 SQL