java 403怎么抛出_django主动抛出403异常的方法详解

前言

网上的做法基本都是下面的代码

return HttpResponseForbidden()

试了一下,效果一般,没有异常页面显示,最终显示的是浏览器的异常页面,如下图:

8f6ba2079386f564778a4fab6d948d47.png

设置方法如下:

如果要想让服务器截获异常并且显示错误页可以用下面的方式:

id = request.GET.get('id', '')

timestamp = request.GET.get('timestamp', '')

accesskey = request.GET.get('accesskey', '')

if timestamp == '' or accesskey == '' or id == '':

raise PermissionDenied

此时访问就会显示正常的错误页了,如下

c81e0446c96585a513ef56d73164cec4.png

django 错误页面定义方法:

urls.py加入如下代码:

handler403 = permission_denied

handler404 = page_not_found

handler500 = page_error

相关view代码:

# Create your views here.

def page_not_found(request):

return HttpResponseRedirect('/static/error_pages/404.html')

def page_error(request):

return HttpResponseRedirect('/static/error_pages/500.html')

def permission_denied(request):

return HttpResponseRedirect('/static/error_pages/403.html')

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值