我使用的是Design-1.5.4和Rails 3.0.20。
Devise提供了一些方法,如current_user、authenticate_user!,它们调用authenticate!,后者本身调用serialize_from_cookie,它们使用remember_token对用户进行身份验证。
此外,serialize_from_cookie方法接收id作为参数,因此它在主键上查询Users表(这是一个自动优化的查询)。
但是,我在select * from users where remember_token = 'XXXXXX'日志中看到类似于MySQL的查询。
由于用户表越来越大,这些查询变得越来越慢。我对此有以下问题:
发布于 2020-08-26 09:01:29
Devise查询以确保在设置新remember_token时没有设置相同的令牌。
https://github.com/heartcombo/devise/blob/master/lib/devise/models/rememberable.rb#L146
# Generate a token checking if one does not already exist in the database.
def remember_token #:nodoc:
loop do
token = Devise.friendly_token
break token unless to_adapter.find_first({ remember_token: token })
end
endhttps://stackoverflow.com/questions/25686531
复制相似问题