当只找到1时,Devise返回2个错误

时间:2012-06-21 19:43:01

标签: ruby-on-rails-3 devise

我为我的应用启用了模块validatable。在我要求用户注册的电子邮件地址的屏幕上,如果电子邮件已经存在...这是我看到的错误:

We found 2 errors that prevented your account from being created:
Email has already been takenEmail has already been taken

这是来自日志:

Started POST "/users" for 127.0.0.1 at 2012-06-21 14:37:41 -0500
Processing by RegistrationsController#create as HTML
  Parameters: {"utf8"=>"✓", "authenticity_token"=>"zcpDH5U4XkHcYWVHEqrshgmzGiqsZHI9mD6Inrdr8uE=", "user"=>{"email"=>"abc@email.com"}, "commit"=>"Sign Me Up!"}
   (0.1ms)  begin transaction
  User Exists (0.2ms)  SELECT 1 AS one FROM "users" WHERE "users"."email" = 'abc@email.com' LIMIT 1
  User Exists (0.1ms)  SELECT 1 AS one FROM "users" WHERE LOWER("users"."email") = LOWER('abc@email.com') LIMIT 1
   (0.1ms)  rollback transaction
  Rendered devise/shared/_links.erb (0.8ms)
  Rendered devise/registrations/new.html.erb within layouts/application (6.5ms)
Completed 200 OK in 1118ms (Views: 290.9ms | ActiveRecord: 0.0ms)

如何通过尝试进行两次检查并只做1?

2 个答案:

答案 0 :(得分:0)

试图登录但它不会让我。

我不做ruby,但看起来你可能正在输入符合这两者标准的电子邮件。可能只需要第二个。希望这有帮助!

User Exists (0.2ms) SELECT 1 AS one FROM "users" WHERE "users"."email" = 'abc@email.com' LIMIT 1
User Exists (0.1ms) SELECT 1 AS one FROM "users" WHERE LOWER("users"."email") = LOWER('abc@email.com') LIMIT 1

答案 1 :(得分:0)

Rails为每个验证运行单独的检查,因此存在和唯一性验证器将导致两次检查。如果要避免冗余错误消息,可以执行以下操作,并仅输出唯一错误消息:

#error_explanation
  .alert.alert-error
    Please correct the following #{pluralize(object.errors.full_messages.uniq.size, "error")}:
   %ul
   - object.errors.full_messages.uniq.each do |msg|
     %li #{msg}