摘要:中自定義了一些,用于監聽一些操作,并發出通知官方解釋提供一個信號分發器,允許解耦的應用在框架的其它地方發生操作時會被通知到。簡單來說,信號允許特定的通知一組某些操作已經發生。或者在請求時,記錄請求信息。
django中自定義了一些singals,用于監聽一些操作,并發出通知
官方解釋:
Django 提供一個“信號分發器”,允許解耦的應用在框架的其它地方發生操作時會被通知到。 簡單來說,信號允許特定的sender通知一組receiver某些操作已經發生。這在多處代碼和同一事件有關聯的情況下很有用。
django中已經內置了一些singals,在django/db/models/signal.py中,如
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 # 創建數據庫連接時,自動觸發
用法:
利用這幾個singals可以實現model中的一些聯動操作,比如,要想更改通過model更新記錄時,記下操作者的日志,可以直接在操作的地方使用post_save裝飾器,
或者改寫post_save,使其記錄相關信息,一勞永逸。或者在request請求時,記錄請求信息。
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. 觸發信號
from 路徑 import pizza_done pizza_done.send(sender="seven",toppings=123, size=456)
需求場景:
項目中有一個需求,當model(即庫的數據)被修改或者刪除時,自動觸發一個redis的同步任務(后來發現這個需求沒有意義....),model的保存有post_save,刪除有post_delete,唯獨沒有update,而代碼中使用update的場景蠻多的,就搜了下為什么就是沒有update的singals。
看到:https://code.djangoproject.co...
其實很早就有人給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被調用時, 發送該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,觸發操作----------
from tools.signals import post_update @receiver(post_update) def post_update_callback(sender, **kwargs): print(kwargs["user"]) print("post_update_success")
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/44792.html
內置的信號量 model:import django.db.models.signals pre_init = ModelSignal(providing_args=[instance, args, kwargs], use_caching=True) post_init = ModelSignal(providing_args=[instance...
摘要:博客網站的用戶信息并不復雜,因此擴展就足夠了。可以在這個基礎上,擴展為一個美觀詳細的用戶信息頁面。當然最好再給個人信息添加一個入口。沒有對用戶的登錄狀態進行檢查。總結本章使用一對一鏈接的方式,擴展并更新了用戶信息。 可能你已經發現了,Django自帶的User模型非常實用,以至于我們沒有寫用戶管理相關的任何模型。 但是自帶的User畢竟可用的字段較少。比方說非常重要的電話號碼、頭像等都...
摘要:轉載說明來源添加全文搜索功能入門一使用的工具是的開源搜索框架,該框架支持搜索引擎,不用更改代碼,直接切換引擎,減少代碼量。修改如下添加修改為如下第二步在中修改引擎,如下第三步重建索引,在進行搜索中文試試吧。 感覺網絡上關于Django全文搜索的中文文章太少,并且講的也不是很到位,就是簡單介紹了怎么配置,并沒有說這樣配置有什么用,所以依然很迷茫。所以希望我這篇文章能夠幫助到后來人。 轉...
摘要:的信號機制就是基于它建立的。觸發信號使用方法通知信號訂閱者。每個元組的組成為。與是兩個不同的信號。這時,可以使用優化信號發送信號通常會進行優化,以便快速的發送。 參考 Blinker Documentation Blinker 是一個基于Python的強大的信號庫,它既支持簡單的對象到對象通信,也支持針對多個對象進行組播。Flask的信號機制就是基于它建立的。 Blinker的內核雖...
閱讀 2654·2023-04-25 15:22
閱讀 2824·2021-10-11 10:58
閱讀 1045·2021-08-30 09:48
閱讀 1851·2019-08-30 15:56
閱讀 1730·2019-08-30 15:53
閱讀 1089·2019-08-29 11:16
閱讀 1048·2019-08-23 18:34
閱讀 1638·2019-08-23 18:12