Django4.0 中间件-编写自己的中间件

2022-03-16 17:59 更新

中间件工厂是一个可调用的程序,它接受 ​get_response ​可调用并返回中间件。中间件是可调用的,它接受请求并返回响应,就像视图一样。

中间件可以被写成这样的函数:

def simple_middleware(get_response):
    # One-time configuration and initialization.

    def middleware(request):
        # Code to be executed for each request before
        # the view (and later middleware) are called.

        response = get_response(request)

        # Code to be executed for each request/response after
        # the view is called.

        return response

    return middleware

或者它可以写成一个类,它的实例是可调用的,如下:

class SimpleMiddleware:
    def __init__(self, get_response):
        self.get_response = get_response
        # One-time configuration and initialization.

    def __call__(self, request):
        # Code to be executed for each request before
        # the view (and later middleware) are called.

        response = self.get_response(request)

        # Code to be executed for each request/response after
        # the view is called.

        return response

Django 提供的 ​get_response ​响应可能是实际视图(如果这是最后列出的中间件),或者它可能是链中的下一个中间件。不需要知道或关心当前的中间件到底是什么,它只是代表了下一步的内容。
以上是一个轻微的简化——链中最后一个中间件调用的 ​get_response ​可不是实际视图,而是处理程序的包装方法,它负责应用 ​view middleware​,调用具有适当URL参数的视图,并应用 ​template-response​ 和 ​exception ​中间件。
中间件可以只支持同步Python(默认),或异步Python,或者二者都支持。
中间件可以放在 Python 路径上的任何地方。

__init__(get_response)

中间件工厂必须接受 ​get_response ​参数。还可以初始化中间件的一些全局状态。记住两个注意事项:

  • Django仅用 ​get_response ​参数初始化您的中间件,因此不能定义 ​__init__()​ ,因为需要其他参数。
  • 与每个请求调用一次的 ​__call__()​ 方法不同,​__init__()​ 仅在 Web 服务器启动时调用一次。

标记未使用的中间件

在启动时确定是否应该使用一个中间件有时是有用的。在这些情况下,您的中间件的 ​__init__()​ 方法可能会引发 ​MiddlewareNotUsed​。Django 将从中间件进程中删除该中间件,并将调试消息记录到 ​django.request​ 日志:设置 ​DEBUG ​为 ​True​。


以上内容是否对您有帮助:
在线笔记
App下载
App下载

扫描二维码

下载编程狮App

公众号
微信公众号

编程狮公众号