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中的参数个数与之对应