Django笔记三十一之全局异常处理 观天下
本文首发于公众号:Hunter后端
原文链接:Django笔记三十一之全局异常处理
这一篇笔记介绍 Django 的全局异常处理。
(资料图片仅供参考)
当我们在处理一个 request 请求时,会尽可能的对接口数据的格式,内部调用的函数做一些异常处理,但可能还是会有一些意想不到的漏网之鱼,造成程序的异常导致不能正常运行,甚至会直接报给前端一个错误。
为了避免这种情况的发生,令我们的后端服务看起来是正常的,就算有报错也可以很体面的给前端一个提示,以及后端做一些错误日志的记录,这里我们引入全局异常的处理。
这里我们会用 Django 的中间件和日志的处理来实现,在本系列文章的第二十九篇和第三十篇,可以先熟悉下这两部分功能的使用。
在介绍中间件的章节,我们介绍了 __call__
() 和 process_view() 函数,其实还有一个 process_exception() 函数,这个函数就是当我们的请求在发生不可预知的报错的情况下,会自动调用的函数。
我们来看这样一个处理的示例:
# hunter/middlewares/exception_middleware.pyimport tracebackfrom django.http import JsonResponseimport logginglogger = logging.getLogger(__name__)class ExceptionMiddleware: def __init__(self, get_response): self.get_response = get_response def __call__(self, request): response = self.get_response(request) return response def process_exception(self, request, exception): traceback_info = traceback.format_exc() logger.info(f"request_path: {request.path}, traceback_info: {traceback_info}") return JsonResponse({"code": -1, "msg": "error"}, status=500)
在这里,我们使用 traceback.format_exc() 函数获取到 exception 的报错信息,然后通过 logger 日志打印输出。
日志信息
这里我们主要输出两个信息,一个是接口请求的路径,request.path,一个是报错信息 traceback_info,当然,这里我们还可以记录更多的信息,比如请求的用户信息,请求的参数等。
记录之后,后端就可以通过日志的具体信息去查看到底是哪里出了问题。
返回报错
在这里,调用 process_exception() 函数之后,我们这里直接 return 了 response,还有一个 http 的状态码 status=500,这些信息都是可以自己拟定的,到时候和前端约定好,检测返回了某个状态码比如 500,然后就友好的显示某个报错弹窗信息,比如后台正在处理报错等。
调用中间件
定义好这个中间件之后,我们就需要在 settings.py 里去引用这个中间件,比如这个中间件我们放置的目录是 hunter/middlewares/exception_middleware.py,就需要在 hunter/settings.py 的 MIDDLEWARE 末尾加上 "hunter.middlewares.exception_middleware.ExceptionMiddleware",
这一条。
# hunter/settings.pyMIDDLEWARE = [ ... "hunter.middlewares.exception_middleware.ExceptionMiddleware",]
测试报错
我们去尝试触发报错信息,比如之前在 第二十九篇笔记中写的一个接口,这里我们修改一下,直接报错:
# blog/views.pyfrom django.http import HttpResponse, JsonResponsedef time_view(request): html = "abc
" 1 / 0 return HttpResponse(html)
然后在页面或者 postman 里调用该接口,就可以在 logger 指定的日志文件里看到关于这一行的具体报错信息啦。
以上就是本篇笔记的全部内容,接下来我会接着介绍一下 Django 里 session 的一个简单应用,也就是说如何判断用户是否登录的一个示例。
如果想获取更多后端相关文章,可扫码关注阅读:
标签:
- Django笔记三十一之全局异常处理 观天下
- 飘若浮云矫若惊龙是什么意思_ldquo 飘若浮云 rdquo 和 ldquo 矫若惊龙 rdquo 是什么意思|环球速看料
- 越秀房托:绿色和可持续发展相关贷款占比38.6% | ESG报告
- 柏文喜:递表再失效对珠海万达商管长期影响不大_焦点热闻
- 自体脂肪填充多久可以恢复?需要做几次-当前独家
- “五一”假期全国将迎来道路出行高峰 公安部发出安全预警|天天新视野
- 终于守得云开见月明,卡米拉佩戴两枚女王的蓝宝石胸针,春风得意
- 两位闪电侠登场,还有女版超人,老年蝙蝠侠也获得新能力! 环球关注
- 意甲第31轮焦点战罗马客场挑战亚特兰大
- AdvanTrade爱跟投:黄金盘整仍有处上涨趋势_报资讯
- 电竞显示屏哪家好?雷神科技国内首批通过电竞显示器性能认证
- 快消息!框架合同范本采购(共4篇)
- 国家市场监管总局广告监管司司长柴保国一行莅临兰考开展主题教育调研座谈会-世界今亮点
- 天天热讯:国金证券:给予同庆楼买入评级
- 山东先达农化股份有限公司拟投资建设年产5000吨烯草酮原药项目|报资讯
- 港股午评:指数低开高走 恒生科技指数涨1.34% |全球报资讯
- 张掖市文广旅局严厉打击侵权盗版行为坚决守好文化安全底线
- 西藏藏东小乡村的一场“特别”演出
- 痛心!佛山一辅警执勤时被撞不幸离世,年仅25岁|环球观察
- 全球观天下!招商中证物联网主题ETF净值下跌2.01% 请保持关注
- 值机更便捷! 拉萨贡嘎机场增设4台自助值机设备
- 绝世唐门之无敌轮回眼_绝世唐门之仙之轮回|环球滚动
- 消息称苹果计划推出AI驱动的健康监测服务_焦点滚动
- 新概念英语第四册短句总结:衰老过程
- 每日快看:个性化定制方案 全过程跟踪服务(一线探民生)
- 世界热点!风神股份:4月25日融资买入139.66万元,融资融券余额6437.26万元
- “每个人的身上都有毛毛”的季节 “梧桐絮”的烦恼怎么破?
- 2023年4月25日湖北省β- 熊果苷价格最新行情预测
- 意大利青训改革:下赛季每支青年队必须至少有5名意大利本土球员_世界新视野
- 动物保健板块4月25日跌1.21%,金河生物领跌,主力资金净流出3519.9万元 焦点消息