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

yizhihongxing

本文首发于公众号: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爬虫使用正则爬取网站的实现

    以下是“Python爬虫使用正则爬取网站的实现”的完整攻略: 一、问题描述 在Python爬虫中,我们经常需要使用正则表达式来爬取网站数据。本文将详细讲解如何使用Python正则表达式爬取网站数据,并提供两个示例说明。 二、解决方案 2.1 获取网站数据 在Python爬虫中,我们可以使用urllib库获取网站数据。以下是一个示例,演示了如何获取网站数据: …

    python 2023年5月14日
    00
  • 使用NumPy在Python中生成Legendre数列的Vandermonde矩阵

    生成Legendre数列的Vandermonde矩阵,需要使用Python中的NumPy库。 首先,导入NumPy库: import numpy as np 然后,使用NumPy提供的函数 np.polynomial.legendre.legvander 生成Legendre数列的Vandermonde矩阵。该函数的基本语法如下: np.polynomial…

    python-answer 2023年3月25日
    00
  • 限制 Python 进程内存使用

    【问题标题】:Limit Python process memory usage限制 Python 进程内存使用 【发布时间】:2023-04-05 10:32:01 【问题描述】: 我有一个内存为 16GB 的系统。我为一些数据挖掘应用程序运行了一个python 脚本,该过程占用了整个 16GB。我想限制python进程只占用有限的内存。 可以这样做吗?如…

    Python开发 2023年4月5日
    00
  • 在Python-NumPy中对多项式进行微分并设置导数

    在Python-NumPy中,可以通过numpy.poly1d类创建多项式对象,而多项式的导函数也可以通过该类的deriv()方法快速求出。下面是完整的攻略: 导入NumPy库: python import numpy as np 使用numpy.poly1d函数创建多项式对象,例如,创建一个三次多项式$f(x)=3x^3+2x^2-3x+1$: pytho…

    python-answer 2023年3月25日
    00
  • python二叉树常用算法总结

    下面是关于“Python二叉树常用算法总结”的完整攻略。 1. 二叉树简介 二叉树是一种树形结构,它的每个节点最多有两个子节点。二叉的节点包含一个值和两个指针分别指向左子树和右子树。二叉树的遍历方式包括前序遍历、中序遍历和后序遍历。 2. Python实现二叉树 在Python中,我们可以使用 Node 类来表示二叉树的节点,使用 BinaryTree 类来…

    python 2023年5月13日
    00
  • centos7.1如何手动安装ceph

    以下是针对CentOS 7.1手动安装Ceph的完整攻略,其中包括两条示例说明: 1. 准备环境 在开始手动安装Ceph之前,需要先确保操作系统已经安装好了必要的依赖。以下命令将安装一些常见的依赖项: sudo yum install epel-release sudo yum install gcc gcc-c++ git autoconf automak…

    python 2023年6月2日
    00
  • 如何使用Python查询包含一个列表中任意一个值的所有行?

    以下是如何使用Python查询包含一个列表中任意一个值的所有行的完整使用攻略。 步骤1:导入模块 在Python中,我们需要导入相应的模块来连接数据库和执行查询操作。以下是导入mysql-connector-python模块的基本语法: import mysql.connector 以下是导入psycopg2模块的基本语法: import psycopg2 …

    python 2023年5月12日
    00
  • Python中查看文件名和文件路径

    下面是Python中查看文件名和路径的完整攻略: 查看文件名 在Python中,可以使用os模块来获取文件的名字,os模块提供了许多处理文件和目录的方法。其中,os.path模块提供了很多获取文件路径、文件名的函数。 使用os.path.basename()函数可以获取文件名,例如: import os file_path = ‘D:/data/test.t…

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