如何在django中提出禁止响应

我想要做以下事情:

raise HttpResponseForbidden()

但我得到的错误:

exceptions must be old-style classes or derived from BaseException, not HttpResponseForbidden

我应该怎么做?


与其他任何响应一样,从视图中返回。

from django.http import HttpResponseForbidden

return HttpResponseForbidden()

如果你想提出一个例外,你可以使用:

from django.core.exceptions import PermissionDenied
raise PermissionDenied

这里记录:

https://docs.djangoproject.com/en/stable/ref/views/#the-403-http-forbidden-view

与Retreat HttpResponseForbidden相反,引发PermissionDenied会导致错误使用403.html模板呈现,或者您可以使用中间件来显示自定义的“Forbidden”视图。


您可以选择提供名为“403.html”的自定义模板来控制403个HTTP错误的呈现。

正如@ dave-halter正确指出的那样,403模板只能在您引发PermissionDenied时使用

以下是用于测试自定义模板“403.html”,“404.html”和“500.html”的示例视图; 请确保在项目设置中设置DEBUG = False,否则框架将显示404和500的回溯。

from django.http import HttpResponse
from django.http import Http404
from django.core.exceptions import PermissionDenied


def index(request):

    html = """
<!DOCTYPE html>
<html lang="en">
  <body>
    <ul>
        <li><a href="/">home</a></li>
        <li><a href="?action=raise403">Raise Error 403</a></li>
        <li><a href="?action=raise404">Raise Error 404</a></li>
        <li><a href="?action=raise500">Raise Error 500</a></li>
    </ul>
  </body>
</html>
"""

    action = request.GET.get('action', '')
    if action == 'raise403':
        raise PermissionDenied
    elif action == 'raise404':
        raise Http404
    elif action == 'raise500':
        raise Exception('Server error')

    return HttpResponse(html)
链接地址: http://www.djcxy.com/p/71811.html

上一篇: How do I raise a Response Forbidden in django

下一篇: ASP.NET Federated Authentication with Cross Domain