首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >acl9和devise似乎不能很好地协同工作

acl9和devise似乎不能很好地协同工作
EN

Stack Overflow用户
提问于 2010-06-13 07:06:51
回答 1查看 554关注 0票数 0

我有一个用户模型,它的访问权限由ACL9控制。

UsersController

代码语言:javascript
复制
#ACL9 related stuff
before_filter :load_user, :only => [:show]
  access_control do
    allow :owner, :of => :user, :to => [:show]
  end

def load_user
  user = User.find(params[:id])
end

ApplicationController

代码语言:javascript
复制
rescue_from 'Acl9::AccessDenied', :with => :access_denied

def access_denied
  authenticate_user! # a method from Devise
end

输入用于登录页面http://localhost:3000/users/sign_in的url是没有问题的,但是当例如我首先输入用户页面时,这是一个问题,我期望通过上面的逻辑被重定向到自动登录页面。

http://localhost:3000/users/1 =>无限重定向地狱。它尝试再次重定向回users/1,而不是定向到users/sign_in

有没有人对可能出错的地方有什么看法?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2010-07-14 13:19:50

我认为你不应该在设计用户控制器中使用Acl9。由于您未通过身份验证,因此您没有权限,也不会进行身份验证:D.您可能希望禁止用户删除,因此应如下所示:

代码语言:javascript
复制
access_control :only => [:destroy] do
      allow :admin
end

对于UsersController,如果你想让它在应用程序控制器中保持原样,你应该覆盖你的access_control。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3030428

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档