【发布时间】:2019-06-15 16:34:05
【问题描述】:
这是MyProj/urls.py的内容:
from django.contrib import admin
from django.urls import path, include
urlpatterns = [
path('admin/', admin.site.urls),
path('', include('general.urls')), # Main app
]
handler403 = 'general.views.handler403'
handler404 = 'general.views.handler403'
如您所见,两个处理程序都指向同一个视图,而我最需要的第一个视图不起作用!例如/obj/12的其他用户的数据显示默认浏览器403页面:
[22/Jan/2019 08:39:14]“GET /obj/12 HTTP/1.1”403 0
但第二个运行良好并显示正确的页面(当尝试访问/obj/768 上的一些不存在的数据时)。为什么以及如何解决?
调试模式已关闭。我的 Django 版本是 2.0.6
更新。
handler403.py 文件的内容:
from django.shortcuts import render_to_response
def handler403(request, *args, **argv):
print('Handler 403 was called!')
u = request.user
params = {
'user': u,
}
response = render_to_response('403.html', params)
response.status_code = 403
return response
当我尝试获取此页面时,从未打印字符串 Handler 403 was called!。
【问题讨论】:
-
您可以使用自定义错误处理程序视图更新您的问题吗?
-
@MohammadUmair 完成。
标签: python django server http-status-code-403