情况很简单:我正在编写一个多用户博客系统。系统应防止非所有者编辑或删除博客文章。在我看来,我使用通用视图。
类博客更新视图(更新视图):...
我知道我应该使用@method_decorator 来装饰调度方法。但是,大多数示例只是 @method_decorator(login_required) 或模型级别权限。如何应用对象级别的权限来检查 request.user 是否是这篇博文的作者?例如,我尝试使用 django-authority 应用程序,我在这个文件中有一个 BlogPermission 类。我试图在这个类中定义一个方法,例如
def blog_edit(self, ??, ??)
我应该在这个方法中加入什么?
然后像这样调用它:
@method_decorator(permission_required('blog_permission.blog_edit(???)'))
我应该在这里传递什么?
更新:阅读method_decorator代码后,我发现它只能接受没有参数的函数。我认为这就是为什么 permission_required 在这里不起作用。但是解决这个问题的方法是什么?
更新解决方案:
在 dispatch 方法中,我检查用户权限,如果用户不满足权限,则返回 HttpResponseForbidden()。