加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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)

我不久前做了这个,但后来不再需要了.如果我记得正确,请告诉我.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读