标签:pop from bsp temp art request 方法 模板 ESS
安装:
pip 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 app = Flask(__name__) # 触发信号要执行的函数 def func(*args,**kwargs): print("触发这个信号",args,kwargs) # 信号绑定函数 signals.request_started.connect(func) # 触发信号 @app.route("/") def index(): return "ok" if __name__ == ‘__main__‘: app.run()
from flask import Flask from flask.signals import _signals app = Flask(import_name=__name__) # 自定义信号 xxxxx = _signals.signal(‘xxxxx‘) # 接收参数的时候,就算send方法不传,也要接收一个参数,后面按照关键字接收参数 def func(*args,**kwargs): print(args,kwargs) # (‘a‘,) {‘k1‘: ‘v1‘} # 自定义信号中注册函数 xxxxx.connect(func) @app.route("/") def index(): # 触发信号 # send(第一个参数必须为位置参数,后面的参数必须为关键字) xxxxx.send(‘a‘,k1=‘v1‘) return ‘Index‘ if __name__ == ‘__main__‘: app.run()
标签:pop from bsp temp art request 方法 模板 ESS
原文地址:https://www.cnblogs.com/baohanblog/p/12532599.html