flask信号
简介
Flask框架中的信号基于blinker,其主要就是让开发者可是在flask请求过程中定制一些用户行为。
pip3 install blinker
内置信号
request_started = _signals.signal('request-started') # 请求到来前执行 request_finished = _signals.signal('request-finished') # 请求结束后执行 before_render_template = _signals.signal('before-render-template') # 模板渲染前执行 template_rendered = _signals.signal('template-rendered') # 模板渲染后执行 got_request_exception = _signals.signal('got-request-exception') # 请求执行出现异常时执行 request_tearing_down = _signals.signal('request-tearing-down') # 请求执行完毕后自动执行(无论成功与否) appcontext_tearing_down = _signals.signal('appcontext-tearing-down')# 应用上下文执行完毕后自动执行(无论成功与否) appcontext_pushed = _signals.signal('appcontext-pushed') # 应用上下文push时执行 appcontext_popped = _signals.signal('appcontext-popped') # 应用上下文pop时执行 message_flashed = _signals.signal('message-flashed') # 调用flask在其中添加数据时,自动触发
使用内置信号
from flask import Flask,signals,render_template,flash app = Flask(__name__) def func1(*args,**kwargs): print('触发信号:request_started') def func2(*args,**kwargs): print('触发信号:appcontext_pushed') signals.request_started.connect(func1) signals.appcontext_pushed.connect(func2) @app.route('/login') def login(): return render_template('index.html') if __name__ == '__main__': app.run()
自定义信号
from flask import Flask, current_app, flash, render_template from flask.signals import _signals app = Flask(import_name=__name__) # 自定义信号 mysignal= _signals.signal('hello world') def func(sender, *args, **kwargs): print(sender) # 自定义信号中注册函数 mysignal.connect(func) @app.route("/x") def index(): # 触发信号 mysignal.send('123123', k1='v1') return 'Index' if __name__ == '__main__': app.run()
思考一下:
信号和before_request装饰器区别?
before_request: 它的返回值 可以控制请求是否可以继续往后执行。
信号: 在原来的基础增加额外的操作和值。

浙公网安备 33010602011771号