ruby-on-rails-3 – Rails在before_filter中不使用条件
发布时间:2020-12-16 21:17:20 所属栏目:百科 来源:网络整理
导读:我在我的应用程序中使用了before_filter.我有一个方法logged_in?如果用户已登录,则返回true. def logged_in? !!current_userenddef current_user @current_user = (User.find(session[:user_id]) if session[:user_id]) || falseend 现在在我的用户控制器中
我在我的应用程序中使用了before_filter.我有一个方法logged_in?如果用户已登录,则返回true.
def logged_in? !!current_user end def current_user @current_user = (User.find(session[:user_id]) if session[:user_id]) || false end 现在在我的用户控制器中,我希望仅在用户未登录时才执行操作.为此,我想在logged_in中使用not condition? before_filter中的方法为: before_filter :!(logged_in?) 但这给了我一个错误.我正在拒绝创建一个未登录的新方法. 请帮我找出完成此任务的正确语法. 解决方法
您可以将块传递给before_filter:
before_filter { |c| !c.logged_in? } 但这不会真正做任何事情,因为前一个过滤器的返回值不会去任何地方.如果要在用户未登录时执行操作,则应将该操作放入before_filter. 例如,如果操作是重定向到登录页面路径,则可以执行以下操作: before_filter { |c| redirect_to login_path unless c.logged_in? } 这实际上足以证明其自身方法的合理性: before_filter :login_required def login_required redirect_to login_path unless logged_in? end (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
- cocos2d-x初探学习笔记(22)--动画类
- 对ajax提交禁用symfony 2 csrf令牌保护
- swift – 使用带有typealias的协议作为属性
- OpenRTMFP/Cumulus Primer(3)图解CumulusEdge原
- ‘service postgresql start’无法在Fedora上启动
- "30年---我与赛灵思FPGA的故事":ZYNQ-7
- 报表XML导出rtf格式,结果在浏览器中打开XML文件
- 正则表达式 – Linux – 只能在一行内找到一个模
- Play!2.1 提示信息flash的使用
- ruby-on-rails – Prawn – 表格单元格内的链接
热点阅读