10

与大多数网站的工作方式相同,我将“UserNaMe”存储在数据库中,但让用户使用“用户名”登录。

这是一个相当明显和必要的功能,似乎很多人都问过它,但我一直绊倒的解决方案似乎与 Devise 自己的文档脱节。

例如,考虑这篇博文: http: //anti-pattern.com/2011/5/16/case-insensitive-keys-with-devise

[...]您可能遇到过这样的问题,即一些用户喜欢在他们的登录名(电子邮件和/或用户名)中以大写形式输入某些字母,但在他们尝试登录时希望它不区分大小写。不是不合理的要求[...]

凉爽的!这就是我想要的。

他的解决方案:

# config/initializers/devise.rb
Devise.setup do |config|
  config.case_insensitive_keys = [:email, :username]
end

这就是我一直在寻找的解决方案。但这是该配置选项的文档:

# Configure which authentication keys should be case-insensitive.
# These keys will be downcased upon creating or modifying a user and when used
# to authenticate or find a user. Default is :email.
config.case_insensitive_keys = [ :username, :email ]

特别是:“这些键将在创建/修改用户时被小写。” 换句话说,用户名在数据库中被小写。

核实:

User.create username: "UsErNaMe", password: "secret", email: "email@com.com"
#=> <User username="username"...>

我错过了一些非常明显的东西吗?

4

1 回答 1

11

devise wiki:您需要find_first_by_auth_conditions在模型中覆盖 devise 的方法。

活动记录示例:

def self.find_first_by_auth_conditions(warden_conditions)
  conditions = warden_conditions.dup
  if login = conditions.delete(:login)
    where(conditions).where(["lower(username) = :value OR lower(email) = :value", { :value => login.downcase }]).first
  else
    where(conditions).first
  end
end

OR lower(email) = :value如果您也不需要通过电子邮件进行身份验证,则可以删除部分。

这样你就不需要列出它usernamecase_insensitive_keys它也不会在数据库中被小写。

于 2012-05-10T11:08:11.800 回答