Django笔记三十一之全局异常处理

本文首发于公众号:Hunter后端

原文链接:Django笔记三十一之全局异常处理

这一篇笔记介绍 Django 的全局异常处理。

当我们在处理一个 request 请求时,会尽可能的对接口数据的格式,内部调用的函数做一些异常处理,但可能还是会有一些意想不到的漏网之鱼,造成程序的异常导致不能正常运行,甚至会直接报给前端一个错误。

为了避免这种情况的发生,令我们的后端服务看起来是正常的,就算有报错也可以很体面的给前端一个提示,以及后端做一些错误日志的记录,这里我们引入全局异常的处理。

这里我们会用 Django 的中间件和日志的处理来实现,在本系列文章的第二十九篇和第三十篇,可以先熟悉下这两部分功能的使用。

在介绍中间件的章节,我们介绍了 __call__() 和 process_view() 函数,其实还有一个 process_exception() 函数,这个函数就是当我们的请求在发生不可预知的报错的情况下,会自动调用的函数。

我们来看这样一个处理的示例:

# hunter/middlewares/exception_middleware.py

import traceback
from django.http import JsonResponse
import logging

logger = 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.py

MIDDLEWARE = [
    ...
    'hunter.middlewares.exception_middleware.ExceptionMiddleware',
]

测试报错

我们去尝试触发报错信息,比如之前在 第二十九篇笔记中写的一个接口,这里我们修改一下,直接报错:

# blog/views.py

from django.http import HttpResponse, JsonResponse

def time_view(request):
    html = "<h1>abc</h1>"
    1 / 0
    return HttpResponse(html)

然后在页面或者 postman 里调用该接口,就可以在 logger 指定的日志文件里看到关于这一行的具体报错信息啦。

以上就是本篇笔记的全部内容,接下来我会接着介绍一下 Django 里 session 的一个简单应用,也就是说如何判断用户是否登录的一个示例。

如果想获取更多后端相关文章,可扫码关注阅读:

image

原文链接:https://www.cnblogs.com/hunterxiong/p/17357139.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Django笔记三十一之全局异常处理 - Python技术站

(0)
上一篇 2023年4月27日
下一篇 2023年4月27日

相关文章

  • 详解Python中append、extend和insert的区别

    append(): append()函数用于将一个新元素添加到列表的末尾,这个新元素可以是任何数据类型,例如int、float、string等。使用代码如下: list1 = [1,2,3,4,5] # 添加新元素6 list1.append(6) # 打印列表 print(list1) 输出结果为[1, 2, 3, 4, 5, 6]。 extend(): …

    python-answer 2023年3月25日
    00
  • matplotlib quiver箭图绘制案例

    那么现在我将为你详细讲解“matplotlib quiver箭图绘制案例”的完整攻略。 什么是matplotlib quiver箭图? quiver是matplotlib中的一个绘图函数,用于绘制箭头图。它通常用于表示向量或流数据。箭头的长度、方向和颜色可以根据你的需要进行调整。 如何使用matplotlib quiver对向量进行绘制? 首先,我们需要导入…

    python 2023年5月19日
    00
  • python数据解析之XPath详解

    XPath是一种用于在XML文档中定位元素和属性的语言。Python提供了多种解析XML数据的方法,其中包括使用XPath表达式解析XML数据。以下是详细讲解Python数据解析之XPath详解,包含两个示例。 示例1:使用XPath解析XML 以下是一个示例,可以使用XPath解析XML: from lxml import etree # 定义XML文档 …

    python 2023年5月15日
    00
  • python psutil库安装教程

    Python Psutil库安装教程 Python Psutil库是一款python系统信息获取工具,可以获取系统CPU、内存、磁盘IO等信息,也可以进行进程管理与控制。本篇教程将介绍Psutil库的安装方法。 环境准备 在安装Psutil库之前,需要先安装好Python环境。可以到Python官网(https://www.python.org/)下载并安装…

    python 2023年5月14日
    00
  • python实现超市进销存管理系统

    Python实现超市进销存管理系统攻略 1. 系统设计 超市进销存管理系统主要包含以下几个模块: 商品管理 进货管理 销售管理 库存管理 报表统计 其中,商品管理模块主要负责商品的添加、修改、删除和查询;进货管理模块主要负责进货单的添加、查询以及进货单与商品库存的更新;销售管理模块主要负责销售单的添加、查询以及销售单与商品库存的更新;库存管理模块主要负责商品…

    python 2023年5月30日
    00
  • python-try-except:pass的用法及说明

    当我们在使用Python编写程序过程中,经常会遇到一些异常错误,如文件找不到,除数为0等。为了避免这些错误导致程序异常终止,可以使用 try 和 except 语句来处理异常情况。 try 语句的工作原理是,首先执行 try 后面的语句块,如果执行成功,就直接跳过 except 语句;如果执行过程中出现了异常,则跳转到 except 语句块中处理异常。 如果…

    python 2023年5月13日
    00
  • Pyinstaller打包Scrapy项目的实现步骤

    Pyinstaller是一款Python的第三方打包工具,它能够将Python的脚本或程序打包为独立的可执行文件,包含所有依赖的库和资源文件。对于使用Scrapy框架的项目,使用Pyinstaller可以很方便地将项目打包成可执行文件,方便在其他环境中部署和运行。 下面是将Scrapy项目使用Pyinstaller打包成可执行文件的步骤: 1. 安装Pyin…

    python 2023年6月3日
    00
  • Python collections模块的使用技巧

    下面给您讲解一下Python collections模块的使用技巧。 Collections模块介绍 Python中的collections模块是一个集合(Container)数据类型,它提供了更多的便利,可以替代Python内置类型,例如list、dict、tuple等。在collections模块中,有许多有用的数据类型,如OrderedDict、def…

    python 2023年5月13日
    00
合作推广
合作推广
分享本页
返回顶部