ruby-on-rails – 如何向Devise添加策略
发布时间:2020-12-17 03:19:12 所属栏目:百科 来源:网络整理
导读:我正在尝试添加一个非常简单的策略来设计,它似乎并没有起作用.这是我尝试使用的代码 #config/initializers/devise.rbDevise.setup do |config| config.orm = :mongo_mapper config.warden do |manager| manager.strategies.add(:auto_login_strategy) do def
我正在尝试添加一个非常简单的策略来设计,它似乎并没有起作用.这是我尝试使用的代码
#config/initializers/devise.rb Devise.setup do |config| config.orm = :mongo_mapper config.warden do |manager| manager.strategies.add(:auto_login_strategy) do def valid? params[:auto_login] end def authenticate! u = User.find(:first) u.nil? ? fail!("No created users") : success!(u) end end manager.default_strategies(:scope=>:user).unshift :auto_login_strategy end end 代码应该检查params的’auto_login’参数,如果存在,找到它可以的第一个??用户并登录.我完全跳过安全措施,只是让一个基本的测试用例工作.当我尝试登录到具有before_filter authenticate_user的控制器时! (即localhost:3000 / test?auto_login = true),它无法登录并重定向到登录页面.我究竟做错了什么? 解决方法
您可能想尝试将其直接添加到Warden :: Strategies:
class MyStrategy def valid?... def authenticate!... end Warden::Strategies.add(:database_authenticatable,MyStrategy) 我不久前做了这个,但后来不再需要了.如果我记得正确,请告诉我. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |