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

从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}%")

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...