标签:信号 app request signals template signal
信号
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在其中添加数据时,自动触发
一个流程中的信号触发点
1. before_first_request
2. 触发 request_started 信号
3. before_request
4. 模板渲染
渲染前的信号 before_render_template.send(app, template=template, context=context)
rv = template.render(context) # 模板渲染
渲染后的信号 template_rendered.send(app, template=template, context=context)
5. after_request
6. session.save_session()
7. 触发 request_finished信号
如果上述过程出错:
触发错误处理信号 got_request_exception.send(self, exception=e)
8. 触发信号 request_tearing_down
一、信号使用
# 请求来触发
from flask import Flask, signals
app = Flask(__name__)
# 向信号中注册函数
def func(*args, **kwargs):
print("触发信号", args, kwargs)
# 请求来之前触发
signals.request_started.connect(func)
# 触发信号: signals.request_started.send()
@app.before_first_request
def request_first1(*args, **kwargs):
pass
@app.before_first_request
def request_first2(*args, **kwargs):
pass
@app.before_request
def request_first3(*args, **kwargs):
pass
@app.route('/', methods=['GET', "POST"])
def index():
print('视图')
return "ok"
if __name__ == '__main__':
# app.__call__()
app.run()
二、自定义信号
from flask import Flask, signals
from flask.signals import _signals
app = Flask(import_name=__name__)
custom_signals = _signals.signal('custom')
def func(*args, **kwargs):
print("自定义信号11", args, kwargs)
# 自定义信号注册
custom_signals.connect(func)
@app.route('/custom')
def index():
# 触发信号
custom_signals.send("自定义信号", k=123)
return '自定义信号'
总结:
- 自定义信号必须要使用才可以触发
- 系统中信号,会在固定时间点自动触发
标签:信号,app,request,signals,template,signal 来源: https://www.cnblogs.com/randysun/p/15518268.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。