前言
网上的做法基本都是下面的代码
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-异常/