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

ruby-on-rails – Devise before_filter authenticate_admin?

发布时间:2020-12-16 19:24:56 所属栏目:百科 来源:网络整理
导读:我通过添加管理员属性为Devise添加了管理员角色. 你能告诉我,这是否是创建一个需要管理员用户签名的before_filter的正确方法: 在任何控制器中: before_filter :authenticate_admin! 在application_controller中 protected unless current_user.try(:admin?
我通过添加管理员属性为Devise添加了管理员角色.

你能告诉我,这是否是创建一个需要管理员用户签名的before_filter的正确方法:

在任何控制器中:

before_filter :authenticate_admin!

在application_controller中

protected
  unless current_user.try(:admin?)      
    redirect_to :new_user_session_path      
  end

解决方法

用这种方法去
before_filter :authenticate_user!
  before_filter do 
    redirect_to new_user_session_path unless current_user && current_user.admin?
  end

这也确保任何客人都被迫登录.您不需要修改默认方法来强制验证只是访问实例方法admin?

def admin?
  self.admin == true
end

我的方法是创建一个角色属性,并根据一组预期的角色来检查其字符串值 – 它的灵活性远远超过了创建许多布尔属性.

(编辑:李大同)

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

    推荐文章
      热点阅读