微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

load_and_authorize_resource 是授权控制器中的每个操作,还是仅授权 RESTful 操作?

如何解决load_and_authorize_resource 是授权控制器中的每个操作,还是仅授权 RESTful 操作?

TL;DR

基本上,我是否必须在不是 7 个 RESTful 认值之一的控制器操作中手动调用 authorize!,还是 load_and_authorize_resource 在这些非标准操作中仍然为我执行此操作?

更长的版本:

我通过 rails scaffold 生成一个控制器,然后添加了几个自定义操作来执行一些随机的其他操作。

在控制器的顶部,我有 load_and_authorize_resource,我相信它会在每个操作中调用 authorize!

它是针对控制器中的每个动作(包括自定义动作)还是由脚手架生成的动作执行此操作? (即index,show,new,edit,create,update,destroy

我从cancancan docs看到:

为每个动作设置此项可能很乏味,因此提供了 load_and_authorize_resource 方法自动授权 RESTful 风格资源控制器中的所有动作。

但我不确定这只是 7 个原件还是开发者添加的其他内容

解决方法

简单的答案是是的,它将适用于所有控制器中的动作

来自cancancan docs on choosing actions

默认情况下,这将应用于控制器中的每个操作,即使它不是 7 个 RESTful 操作之一。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。