Django之信号

问题:如何对所有数据库的添加操作进行日志记录?

问题:信号和中间件的区别?

Django自带一套信号发射系统来帮助我们在框架的不同位置传递信息,也就是说,当某一事件发生时,信号系统可以允许一个或多个发送者(senders)将通知或信号推送给一组接受者,信号系统在我们多处代码与同一个事件相关是特别有用的。

既然是信号系统,那么必须包含以下要素:

  1. 发送者- 谁发送了信号

  2. 信号- 发送的信号本身

  3. 接收者- 信号是发给谁的

Django的内置信号

Model signals
    pre_init                    # django的modal执行其构造方法前,自动触发
    post_init                   # django的modal执行其构造方法后,自动触发
    pre_save                    # django的modal对象保存前,自动触发
    post_save                   # django的modal对象保存后,自动触发
    pre_delete                  # django的modal对象删除前,自动触发
    post_delete                 # django的modal对象删除后,自动触发
    m2m_changed                 # django的modal中使用m2m字段操作第三张表(add,remove,clear)前后,自动触发
    class_prepared              # 程序启动时,检测已注册的app中modal类,对于每一个类,自动触发
Management signals
    pre_migrate                 # 执行migrate命令前,自动触发
    post_migrate                # 执行migrate命令后,自动触发
Request/response signals
    request_started             # 请求到来前,自动触发
    request_finished            # 请求结束后,自动触发
    got_request_exception       # 请求异常后,自动触发
Test signals
    setting_changed             # 使用test测试修改配置文件时,自动触发
    template_rendered           # 使用test测试渲染模板时,自动触发
Database Wrappers
    connection_created          # 创建数据库连接时,自动触发

对于Django内置的信号,仅需注册指定信号,当程序执行相应操作时,自动触发注册函数:

注意:必须在全局的__init__.py的文件中注册指定信号,
from django.db.models.signals import pre_save, post_save

def callback1(sender,**kwargs):
print("callback1:",sender,kwargs)
print(kwargs["instance"].name)
pre_save.connect(callback1)
每当models执行保存操作之前就会执行callback1函数!
所以,在这个函数中可以记录插入数据库的具体数据。。。。。。
注意查看参数kwargs

自定义信号

a. 定义信号

新建一个py文件,比如:my_signal.py
from django import dispatch

mySignal = dispatch.SIgnal(providing_args=["toppings","size"])

b. 注册信号

把自定义的信号py文件导入到全局的__init__.py文件
和内置信号的注册方法一样:
from my_signal import mySignal

def callback1(sender,**kwargs):
print("callback1:",sender,kwargs)

mySignal.connect(callback1)

c. 触发信号

在任意函数中,首先导入你自定义的信号:
from my_signal import mySignal
然后发送信号,指定发送者:
mySignal.send("egon发送者",toppings="aaa",size=123)可以有任意多个参数,并且my_signal中的参数个数与之对应

 

原文地址:https://www.cnblogs.com/guomeina/p/7562109.html