首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Rails -会话中的ACL9缓存

Rails -会话中的ACL9缓存
EN

Stack Overflow用户
提问于 2010-05-01 02:28:08
回答 1查看 438关注 0票数 1

我用Authlogic实现了身份验证,用Acl9实现了授权。现在,我试图避免多次命中数据库,以检查用户是否为管理员,方法是将其保留在会话中。

我认为这段代码应该可以工作:

代码语言:javascript
复制
class ApplicationController < ActionController::Base
  ...
  helper_method :current_user_session, :current_user, :is_admin
  ...

  private
    def is_admin
      return current_user_session[:is_admin] if defined?(current_user_session[:is_admin])
      current_user_session[:is_admin] = current_user.has_role?(:admin)  
    end

因此,基本上在第一次调用is_admin帮助器方法时,它应该向session[:is_admin]添加一个布尔值,然后对于任何其他调用,从会话中获取该值。但是我收到了这个错误:

代码语言:javascript
复制
undefined method `[]=' for #<UserSession: {:unauthorized_record=>"<protected>"}>

而我却被困在这里。我做错了什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2010-05-07 00:59:53

我不得不使用session[]而不是current_user_session[]。这段代码的效果很不错:

(ApplicationController)

代码语言:javascript
复制
helper_method :current_user_session, :current_user, :is_admin?
    ...
def is_admin?
    return session[:is_admin] if !session[:is_admin].nil?
    session[:is_admin] = current_user.has_role?(:admin)
end

(视图模板)

代码语言:javascript
复制
<% if is_admin? -%>
...

它将在第一次尝试时缓存会话中的管理员角色,然后从那里获取它。

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

https://stackoverflow.com/questions/2746767

复制
相关文章

相似问题

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