在你的主要内容下,views.py
添加你自己的以下两个视图的自定义实现,然后只需设置要显示的模板404.html和500.html
。
这是代码:
from django.shortcuts import render_to_response
from django.template import RequestContext
def handler404(request, *args, **argv):
response = render_to_response('404.html', {},
context_instance=RequestContext(request))
response.status_code = 404
return response
def handler500(request, *args, **argv):
response = render_to_response('500.html', {},
context_instance=RequestContext(request))
response.status_code = 500
return response
更新资料
handler404
和handler500
导出的Django字符串配置变量django/conf/urls/__init__.py
。这就是为什么上面的配置起作用的原因。
为了使上述配置生效,你应该在urls.py
文件中定义以下变量,并将导出的Django变量指向定义这些Django功能视图的字符串Python路径,如下所示:
# project/urls.py
handler404 = 'my_app.views.handler404'
handler500 = 'my_app.views.handler500'
处理程序视图的签名在Django 2.0中已更改:https : //docs.djangoproject.com/en/2.0/ref/views/#error-views
如果你使用上述视图,则handler404将失败并显示以下消息:
“ handler404()获得了意外的关键字参数’exception’”
def handler404(request, exception, template_name="404.html"):
response = render_to_response(template_name)
response.status_code = 404
return response