前言
网上的做法基本都是下面的代码
1
|
return httpresponseforbidden() |
试了一下,效果一般,没有异常页面显示,最终显示的是浏览器的异常页面,如下图:
设置方法如下:
如果要想让服务器截获异常并且显示错误页可以用下面的方式:
1
2
3
4
5
6
|
id = request.get.get( 'id' , '') timestamp = request.get.get( 'timestamp' , '') accesskey = request.get.get( 'accesskey' , '') if timestamp = = ' ' or accesskey == ' ' or id == ' ': raise permissiondenied |
此时访问就会显示正常的错误页了,如下
django 错误页面定义方法:
urls.py加入如下代码:
1
2
3
|
handler403 = permission_denied handler404 = page_not_found handler500 = page_error |
相关view代码:
1
2
3
4
5
6
7
8
9
10
11
|
# 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' ) |
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。
原文链接:http://www.h4ck.org.cn/2018/12/django-主动抛出-403-异常/