django - 使用 UserPassesTestMixin(基于类的 View )和重定向

标签 django django-views django-authentication django-class-based-views django-users

我正在尝试使用基于类的 View ,而我最终得到的是默认的 403 Forbidden 页面..mixin 类的顺序是否正确?代码是否甚至在 get/post 中被使用 - 还是所有内容都被绕过并发生默认的 403 重定向?

到目前为止看到的所有工作示例,仅指向基于函数的 View 中的装饰器 @login_required 并使用请求对象重定向到登录页面。
documentation提供了一些提示,但我无法让它与下面的代码一起工作.. 也放置错误堆栈。

查看

 "GET / HTTP/1.1" 200 2580
Forbidden (Permission denied): /app/custom-view
Traceback (most recent call last):
  File "C:\Users\me\.envs\project\lib\site-packages\django\core\handlers\exception.py", line 34, in inner
    response = get_response(request)
  File "C:\Users\me\.envs\project\lib\site-packages\django\core\handlers\base.py", line 126, in _get_response
    response = self.process_exception_by_middleware(e, request)
  File "C:\Users\me\.envs\project\lib\site-packages\django\core\handlers\base.py", line 124, in _get_response
    response = wrapped_callback(request, *callback_args, **callback_kwargs)
  File "C:\Users\me\.envs\project\lib\site-packages\django\views\generic\base.py", line 68, in view
    return self.dispatch(request, *args, **kwargs)
  File "C:\Users\me\.envs\project\lib\site-packages\django\contrib\auth\mixins.py", line 52, in dispatch
    return super().dispatch(request, *args, **kwargs)
  File "C:\Users\me\.envs\project\lib\site-packages\django\contrib\auth\mixins.py", line 108, in dispatch
    return self.handle_no_permission()
  File "C:\Users\me\.envs\project\lib\site-packages\django\contrib\auth\mixins.py", line 43, in handle_no_permission
    raise PermissionDenied(self.get_permission_denied_message())
django.core.exceptions.PermissionDenied

代码:
 class UserIsAdminMixin(UserPassesTestMixin):
        def test_func(self):
            return request.user.groups.filter(name='CustomAdmin').exists()

    class CustomAdminView(LoginRequiredMixin, UserIsAdminMixin, TemplateView):
        template_name = 'template.html'
        # login_url = '/login/'
        # redirect_field_name = 'my_link_name'

        def get(self, request):
            form = CustomForm()
            # This does not work neither does setting up login_url 
            if not request.user.is_authenticated or not request.user.is_staff or not self.request.user.groups.filter(name='CustomAdmin').exists():
                return redirect('%s?next=%s' % (settings.LOGIN_URL, request.path))

我愿意尝试this solution , 如果上述方法不起作用

最佳答案

根据 this answer ,您可以使用 handle_no_permission(self):处理重定向 URL。

简单地:

def handle_no_permission(self):
    return redirect('users:create-profile')

关于django - 使用 UserPassesTestMixin(基于类的 View )和重定向,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53952412/

相关文章:

python - 在验证和保存表单之前,如何从 ImageField 打开图像?

python - 当数据不为空时,由于空约束,保存数据失败

python - Pip 无法在 ubuntu 服务器上安装任何东西

jquery - Django ajax jquery 文件上传

django - 在 Django 中动态更改 QuerySet 对象

django - 如何更改模型标签并为其指定自定义名称

python - 默认用户模型 OneToOneField 属性错误

Django auth_view 和通用的基于类的 View

python - 使用两种不同的方式创建 django 用户

Django - 如何为注册站点用户和非站点用户提供模型?