gpt4 book ai didi

ruby-on-rails - 如何在事件记录 where 子句中使用通配符同时防止 sql 注入(inject)

转载 作者:行者123 更新时间:2023-12-03 13:25:52 25 4
gpt4 key购买 nike

从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 注入(inject)的影响,但如果我这样做:
User.where("first_name LIKE '%?%'", first_name)

然后生成的 sql 如下所示:
SELECT "users".* FROM "users"  WHERE (first_name LIKE '%'michael'%')

由于额外的单引号,这是无效的。

使用通配符和 LIKE 子句的最佳方法是什么,同时还可以防止 sql 注入(inject)攻击?

最佳答案

您应该像这样修改您的查询

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

关于ruby-on-rails - 如何在事件记录 where 子句中使用通配符同时防止 sql 注入(inject),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13529804/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com