标签:python django exception-handling django-views middleware
我有一个设置了handler500的django应用程序.我想为它添加自定义异常处理程序.
我创建了一个处理进程异常的中间件:
Django calls process_exception() when a view raises an exception. process_exception() should return either None or an HttpResponse object. If it returns an HttpResponse object, the response will be returned to the browser. Otherwise, default exception handling kicks in.
https://docs.djangoproject.com/en/dev/topics/http/middleware/?from=olddocs#process-exception
我的ErrorMiddleware看起来像:
class ErrorMiddleware(object):
def process_exception(self, request, exception):
try:
#logic goes here
except Exception:
pass
return None
我的设置如下:
MIDDLEWARE_CLASSES = (
'my.error.ErrorMiddleware',
'django.middleware.common.CommonMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
)
DEBUG = False
在这种情况下,我的浏览器永远不会从页面获得异常响应.虽然列表中没有我的中间件,但我得到handler500正常工作.
我希望执行默认的异常处理机制,而不在我的中间件中显式调用handler500视图.
UPD:
handler500模块看起来像这样:
#imports ....
def custom_500(request):
""" Return an error ID (hash) that can be provided to support """
return render(request, '500.html', {
'timestamp': datetime.datetime.now().isoformat(),
'diagcode': "hello",
}
)
解决方法:
尝试将您的中间件移动到MIDDLEWARE_CLASSES堆栈的底部,这样它就是第一个在向客户端发出请求时处理请求的中间件.我相信Django已经捕获了你的异常并且如果你把它放在最后那么它会呈现自己的错误500页.
标签:python,django,exception-handling,django-views,middleware 来源: https://codeday.me/bug/20190901/1785240.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。