返回顶部

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: 它的返回值 可以控制请求是否可以继续往后执行。

信号: 在原来的基础增加额外的操作和值。

 

posted @ 2020-10-05 20:47  muguangrui  阅读(53)  评论(0)    收藏  举报