我正在使用Devise-1.5.4和Rails 3.0.20。
Devise提供current_user
,authenticate_user!
等方法,调用authenticate!
,它本身调用serialize_from_cookie
,使用remember_token
对用户进行身份验证。
此外,serialize_from_cookie
方法接收id
作为参数,以便查询主键上的Users
表(自动为优化查询)。
但是,我在MySQL日志中看到select * from users where remember_token = 'XXXXXX'
等查询。
由于users表变得越来越大,这些查询变得越来越慢。我有以下问题:
答案 0 :(得分:1)
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
end