加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails – 如何在活动记录中使用通配符where子句,同时防

发布时间:2020-12-16 19:43:30 所属栏目:百科 来源:网络整理
导读:从rails的活动记录查询 guide on sql injection This code is highly preferable: Client.where(“orders_count = ?”,params[:orders]) 到这段代码: Client.where(“orders_count = #{params[:orders]}”) 我的问题是我想使用带有通配符的LIKE子句.我的旧
从rails的活动记录查询 guide on sql injection

This code is highly preferable:

Client.where(“orders_count = ?”,params[:orders])


到这段代码:

Client.where(“orders_count = #{params[:orders]}”)

我的问题是我想使用带有通配符的LIKE子句.我的旧查询看起来像这样 –

User.where("first_name LIKE '%#{first_name}%'")

哪个容易受到sql注入,但如果我这样做:

User.where("first_name LIKE '%?%'",first_name)

然后生成的sql看起来像:

SELECT "users".* FROM "users"  WHERE (first_name LIKE '%'michael'%')

由于额外的单引号无效.

使用通配符和LIKE子句的最佳方式是什么,但也可以防止sql注入攻击?

解决方法

你应该像这样修改你的查询
User.where("first_name LIKE (?)","%#{first_name}%")

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读