#{}和${}的区别

#{}和${}的区别

  1. #{}相对安全,它的sql是预处理,不会存在sql注入的问题,而${}可能存在sql注入的安全性问题的;
  2. #{}在替换字符串参数时会加上单引号,所以对于(MySQL)系统关键字,所以此方法是不适用的,而${}它能使用SQL所有的替换。

SQL安全问题的解决方案

  1. 尽量使用预处理的#{}的方式进行参数的替换
  2. 在进行数据库操作前,先手动的对传输的参数进行过滤操作,来防止SQL注入。
  3. 尽量使用系统提供的内置方法配合#{}的方式来进行参数的替换,如concat(’%’,#{},’%’);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值