我的项目中有用户和管理员角色。我用Devise创建了我的身份验证。
在我的管理员角色中,我没有任何确认。在我的用户模型中,我有以下内容:
devise :database_authenticatable, :confirmable, :recoverable,
:rememberable, :trackable, :validatable, :timeoutable, :registerable
# Setup accessible (or protected) attributes for your model
attr_accessible :email, :username, :prename, :surname, :phone, :street, :number, :location,
:password, :password_confirmation
我的迁移如下:
class DeviseCreateUsers < ActiveRecord::Migration
def self.up
create_table(:users) do |t|
t.database_authenticatable :null => false
t.confirmable
t.recoverable
t.rememberable
t.trackable
t.timeoutable
t.validateable
t.string :username
t.string :prename
t.string :surname
t.string :phone
t.string :street
t.integer :number
t.string :location
t.timestamps
end
add_index :users, :email, :unique => true
add_index :users, :confirmation_token, :unique => true
add_index :users, :reset_password_token, :unique => true
add_index :users, :username, :unique => true
add_index :users, :prename, :unique => false
add_index :users, :surname, :unique => false
add_index :users, :phone, :unique => false
add_index :users, :street, :unique => false
add_index :users, :number, :unique => false
add_index :users, :location, :unique => false
end
def self.down
drop_table :users
end
end
在我的routes.rb中,我添加了以下语句:
map.devise_for :admins
map.devise_for :users, :path_names => { :sign_up => "register", :sign_in => "login" }
map.root :controller => "main"
用户注册后,我被重定向到控制器main
,并带有闪存通知,“您已成功注册”,我已登录。但我不想登录,因为我有尚未确认我的新用户帐户。
如果我打开控制台,我会在日志中看到确认邮件文本,但我已经登录了。我无法解释原因。有没有人有想法?
如果我从日志中复制出确认令牌并确认我的帐户,我可以登录,但如果我不确认,我也可以登录。
答案 0 :(得分:10)
在config / initializers / devise.rb中,有一行用于设置用户在被锁定之前必须确认的时间。
config.confirm_within = 2.days
如果将其设置为0,则应获得所需的结果。