首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >基于remember_token的设计优化用户查找查询

基于remember_token的设计优化用户查找查询
EN

Stack Overflow用户
提问于 2014-09-05 12:59:36
回答 1查看 312关注 0票数 1

我使用的是Design-1.5.4和Rails 3.0.20。

Devise提供了一些方法,如current_userauthenticate_user!,它们调用authenticate!,后者本身调用serialize_from_cookie,它们使用remember_token对用户进行身份验证。

此外,serialize_from_cookie方法接收id作为参数,因此它在主键上查询Users表(这是一个自动优化的查询)。

但是,我在select * from users where remember_token = 'XXXXXX'日志中看到类似于MySQL的查询。

由于用户表越来越大,这些查询变得越来越慢。我对此有以下问题:

  1. 我无法调试(在代码中)在哪里设计这样的查询?
  2. 我如何优化这些查询(除了添加索引)?
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-08-26 09:01:29

Devise查询以确保在设置新remember_token时没有设置相同的令牌。

https://github.com/heartcombo/devise/blob/master/lib/devise/models/rememberable.rb#L146

代码语言:javascript
复制
# 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
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25686531

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档