flask信号:
安装:
flask中的信号使用的是一个第三方插件,叫做blinker。通过pip list看一下,如果没有安装,通过以下命令即可安装blinker:
pip install blinker
内置信号:
flask内置集中常用的信号:
- flask.template_rendered:模版渲染完毕后发送,示例如下:- from flask import template_rendered def log_template_renders(sender,template,context,*args): print 'sender:',sender print 'template:',template print 'context:',context template_rendered.connect(log_template_renders,app)
- flask.request_started:请求开始之前,在到达视图函数之前发送,订阅者可以调用- request之类的标准全局代理访问请求。示例如下:- def log_request_started(sender,**extra): print 'sender:',sender print 'extra:',extra request_started.connect(log_request_started,app)
- flask.request_finished:请求结束时,在响应发送给客户端之前发送,可以传递- response,示例代码如下:- def log_request_finished(sender,response,*args): print 'response:',response request_finished.connect(log_request_finished,app)
- flask.got_request_exception:在请求过程中抛出异常时发送,异常本身会通过- exception传递到订阅的函数。示例代码如下:- def log_exception_finished(sender,exception,*args): print 'sender:',sender print type(exception) got_request_exception.connect(log_exception_finished,app)
- flask.request_tearing_down:请求被销毁的时候发送,即使在请求过程中发生异常,也会发送,示例代码如下:- def log_request_tearing_down(sender,**kwargs): print 'coming...' request_tearing_down.connect(log_request_tearing_down,app)
- flask.appcontext_tearing_down:在应用上下文销毁的时候发送,它总是会被调用,即使发生异常。示例代码如下:- def log_appcontext_tearing_down(sender,**kwargs): print 'coming...' appcontext_tearing_down.connect(log_appcontext_tearing_down,app)
自定义信号:
自定义信号分为3步,第一是定义一个信号,第二是监听一个信号,第三是发送一个信号。以下将对这三步进行讲解:
- 定义信号:定义信号需要使用到 - blinker这个包的- Namespace类来创建一个命名空间。比如定义一个在访问了某个视图函数的时候的信号。示例代码如下:- from blinker import Namespace mysignal = Namespace() visit_signal = mysignal.signal('visit-signal')
- 监听信号:监听信号使用 - singal对象的- connect方法,在这个方法中需要传递一个函数,用来接收以后监听到这个信号该做的事情。示例代码如下:- def visit_func(sender,username): print(sender) print(username) mysignal.connect(visit_func)
- 发送信号:发送信号使用 - singal对象的- send方法,这个方法可以传递一些其他参数过去。示例代码如下:- mysignal.send(username='zhiliao')