在我的Rails应用程序中,我使用Devise gem来验证用户身份。如果我从管理面板创建用户,我需要跳过电子邮件验证。到目前为止,我有这段代码:
# User model
class User < ApplicationRecord
attr_accessor :skip_email_validation
devise :database_authenticatable, :registerable,
:recoverable, :rememberable, :trackable
validates :email, presence: true, uniqueness: true, unless: :skip_email_validation
end
#User's controller create action
class Admin::UsersController < Admin::AdminController
def create
@user = User.new(user_params)
@user.skip_email_validation = true
if @user.save
redirect_to admin_user_path(@user), success: 'User created.'
else
render :new
end
end
end
因此,当我创建第一个没有电子邮件的用户时,它被保存到数据库中,但是当我创建另一个没有电子邮件的用户时,我有一个错误:
Mysql2::Error: Duplicate entry '' for key 'index_users_on_email': INSERT INTO `users`
我不明白导致此错误的原因,因为我跳过了模型中存在性和唯一性的验证。谢谢你的回答。
答案 0 :(得分:2)
您可能需要在数据库级别进行更改。
Devise在Users表上使用唯一索引。
Devise在迁移中有以下内容:
add_index :users, :email, unique: true
会在db/schema.rb
t.index ["email"], name: "index_users_on_email", unique: true
您需要在迁移/架构中更改它并重置数据库。 `