亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

深入理解Django自定義信號(signals)

 更新時間:2018年10月15日 11:31:15   作者:二二向箔  
這篇文章主要介紹了深入理解Django自定義信號(signals),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

django中自定義了一些singals,用于監(jiān)聽一些操作,并發(fā)出通知

官方解釋:

Django 提供一個“信號分發(fā)器”,允許解耦的應用在框架的其它地方發(fā)生操作時會被通知到。

簡單來說,信號允許特定的sender通知一組receiver某些操作已經(jīng)發(fā)生。這在多處代碼和同一事件有關聯(lián)的情況下很有用。
django中已經(jīng)內置了一些singals,在django/db/models/signal.py中,如

Model signals
  pre_init          # django的modal執(zhí)行其構造方法前,自動觸發(fā)
  post_init          # django的modal執(zhí)行其構造方法后,自動觸發(fā)
  pre_save          # django的modal對象保存前,自動觸發(fā)
  post_save          # django的modal對象保存后,自動觸發(fā)
  pre_delete         # django的modal對象刪除前,自動觸發(fā)
  post_delete         # django的modal對象刪除后,自動觸發(fā)
  m2m_changed         # django的modal中使用m2m字段操作第三張(add,remove,clear)前后,自動觸發(fā)
  class_prepared       # 程序啟動時,檢測已注冊的app中modal類,對于每一個類,自動觸發(fā)
  
Management signals
  pre_migrate         # 執(zhí)行migrate命令前,自動觸發(fā)
  post_migrate        # 執(zhí)行migrate命令后,自動觸發(fā)
  
Request/response signals
  request_started       # 請求到來前,自動觸發(fā)
  request_finished      # 請求結束后,自動觸發(fā)
  got_request_exception    # 請求異常后,自動觸發(fā)
  
Test signals
  setting_changed       # 使用test測試修改配置文件時,自動觸發(fā)
  template_rendered      # 使用test測試渲染模板時,自動觸發(fā)
  
Database Wrappers
  connection_created     # 創(chuàng)建數(shù)據(jù)庫連接時,自動觸發(fā)

用法:

利用這幾個singals可以實現(xiàn)model中的一些聯(lián)動操作,比如,要想更改通過model更新記錄時,記下操作者的日志,可以直接在操作的地方使用post_save裝飾器,

或者改寫post_save,使其記錄相關信息,一勞永逸?;蛘咴趓equest請求時,記錄請求信息。

from django.core.signals import request_finished
from django.dispatch import receiver

@receiver(request_finished)
def my_callback(sender, **kwargs):
  print("Request finished!")

如何自定義singals?

a. 定義singal文件

import django.dispatch
pizza_done = django.dispatch.Signal(providing_args=["toppings", "size"])

b. 注冊singal

def callback(sender, **kwargs):
  print("callback")
  print(sender,kwargs)
  pizza_done.connect(callback) 

c. 觸發(fā)信號

from 路徑 import pizza_done
pizza_done.send(sender='seven',toppings=123, size=456)

需求場景:

項目中有一個需求,當model(即庫的數(shù)據(jù))被修改或者刪除時,自動觸發(fā)一個redis的同步任務(后來發(fā)現(xiàn)這個需求沒有意義....),model的保存有post_save,刪除有post_delete,唯獨沒有update,而代碼中使用update的場景蠻多的,就搜了下為什么就是沒有update的singals。

看到:https://code.djangoproject.com/ticket/12184

其實很早就有人給django官方提過這種方式,為什么不在官方版本中添加,具體這個pr為什么沒有被接受,可以看下里面的討論,反正當時的django1.9仍然不支持,只能自己先寫一個用用,有問題了再撤掉好了。

解決方式:

singals.py文件

# coding:utf-8
from django.dispatch import Signal
post_update = Signal(providing_args=["user"])

models.py文件

-----------針對某個model,重寫其queryset中的update方法-----------

//引入自定義的signal文件
from tools import signals 

class MyCustomQuerySet(models.query.QuerySet):
  def update(self, **kwargs):
    super(MyCustomQuerySet, self).update(**kwargs)
    //update被調用時, 發(fā)送該singalsignals
    signals.post_update.send(sender=self.model, user="xxx")
    print("finished!")

class MyCustomManager(models.Manager):
  def get_queryset(self):
    return MyCustomQuerySet(self.model, using=self._db)

class crontab_ping(models.Model):
  name = models.CharField(max_length=64, blank=True, null=True)
  objects = MyCustomManager()

callback.py文件:

-------接收signal,觸發(fā)操作----------

from tools.signals import post_update

@receiver(post_update)
def post_update_callback(sender, **kwargs):
  print(kwargs['user'])
  print("post_update_success")

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

最新評論