我在我的 Rails 应用程序中使用设计进行身份验证。
我不断收到不同的错误,例如“用户:类的未定义方法 XXXX”。寻找一些帮助来正确设置设计。
我为用户设置了模块 database_authenticable,但我遇到了错误:
undefined method `params_authenticatable?' for User:Class
它来自 lib/devise/strategies/authenticatable.rb 中的以下设计代码
def params_authenticatable?
mapping.to.params_authenticatable?(authenticatable_name)
end
这是我的设计设置:
class User < ActiveRecord::Base
rolify
# Include default devise modules. Others available are:
# :token_authenticatable, :confirmable,
# :lockable, :timeoutable and :omniauthable
devise :database_authenticatable, :registerable,
:recoverable, :trackable, :validatable , :omniauthable, :omniauth_providers => [:linkedin]
.
.
end
class DeviseCreateUsers < ActiveRecord::Migration
def change
create_table(:users) do |t|
## Database authenticatable
t.string :email, :null => false, :default => ""
t.string :encrypted_password, :null => false, :default => ""
## Recoverable
t.string :reset_password_token
t.datetime :reset_password_sent_at
## Rememberable
t.datetime :remember_created_at
## Trackable
t.integer :sign_in_count, :default => 0
t.datetime :current_sign_in_at
t.datetime :last_sign_in_at
t.string :current_sign_in_ip
t.string :last_sign_in_ip
## Confirmable
# t.string :confirmation_token
# t.datetime :confirmed_at
# t.datetime :confirmation_sent_at
# t.string :unconfirmed_email # Only if using reconfirmable
## Lockable
# t.integer :failed_attempts, :default => 0 # Only if lock strategy is :failed_attempts
# t.string :unlock_token # Only if unlock strategy is :email or :both
# t.datetime :locked_at
## Token authenticatable
# t.string :authentication_token
t.timestamps
end
add_index :users, :email, :unique => true
add_index :users, :reset_password_token, :unique => true
# add_index :users, :confirmation_token, :unique => true
# add_index :users, :unlock_token, :unique => true
# add_index :users, :authentication_token, :unique => true
end
end
Mu 身份验证要求很简单,我想使用 Linkedin 身份验证并最终允许其他全向身份验证。
我想知道我是否应该使用 socery 或其他东西来进行简单的身份验证
谢谢 !
我正在使用 Rails4.0