Flask--信号 blinker

Flask--信号 blinker

Flask框架中的信号基于blinker,可以让开发者在flask请求过程中 定制一些用户行为执行。

在请求前后,模板渲染前后,上下文前后,异常 的时候

 

安装:

pip install blinker

 

1 Flask的内置信号:

    内部通过 send方法 触发信号

    2     request_started = _signals.signal('request-started')  # 请求到来前执行
    5 request_finished = _signals.signal('request-finished') # 请求结束后执行 3 before_render_template = _signals.signal('before-render-template') # 模板渲染前执行 4 template_rendered = _signals.signal('template-rendered') # 模板渲染后执行 0 got_request_exception = _signals.signal('got-request-exception') # 请求执行出现异常时执行 6 request_tearing_down = _signals.signal('request-tearing-down') # 请求执行完毕后自动执行(无论成功与否) 7 appcontext_tearing_down = _signals.signal('appcontext-tearing-down') # 请求上下文执行完毕后自动执行(无论成功与否) 1 appcontext_pushed = _signals.signal('appcontext-pushed') # 请求上下文push时执行,一般用不到 8 appcontext_popped = _signals.signal('appcontext-popped') # 请求上下文pop时执行 message_flashed = _signals.signal('message-flashed') # flash消息的时候-- 调用flask在其中添加数据时,自动触发

补充:Django的信号

Model signals      # ORM 操作的时候触发

    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 # 创建数据库连接时,自动触发

使用:

from django.core.signals import request_finished from django.core.signals import request_started from django.core.signals import got_request_exception from django.db.models.signals import class_prepared from django.db.models.signals import pre_init, post_init from django.db.models.signals import pre_save, post_save from django.db.models.signals import pre_delete, post_delete from django.db.models.signals import m2m_changed from django.db.models.signals import pre_migrate, post_migrate from django.test.signals import setting_changed from django.test.signals import template_rendered from django.db.backends.signals import connection_created def callback(sender, **kwargs): print("xxoo_callback") print(sender,kwargs) 信号.connect(callback)

自定义信号

a. 定义信号

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

b. 注册信号

    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)

 

2 特殊装饰器 与 信号的区别

信号的功能 都可以 通过扩展实现

区别:

    1  返回值:注册到信号的函数,没有返回值, 只执行自定义操作

    2  自定义信号,可以降低代码的耦合

 

3 自定义信号的实现:( 发送消息 )

def QQ(*args,**kwargs):
    pass

def WX(*args,**kwargs): pass from flask.signals import _signals MSG = _signals.signal('MSG') # 创建信号 MSG.connect(QQ) # 注册 MSG.connect(WX) @app.route('/',methods=['GET','POST'],endpoint='index') def index(): MSG.send(sender='xxx',a=1,b=2) # 触发 return render_template('login.html') if __name__ == '__main__': app.run()

使用例子:

关于请求进来 >>.先执行 扩展的装饰器 before_first_request >> 然后request_start信号 >> 然后 before_request , 然后视图

@app.before_first_request
def sayhello(): print('hello11') def test(*args,**kwargs): print('test22') from flask.signals import request_started request_started.connect(test) @app.route('/',methods=['GET','POST'],endpoint='index') def index(): return 'hello333' if __name__ == '__main__': app.run()

转载于:https://www.cnblogs.com/ExMan/p/9875931.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值