zoukankan      html  css  js  c++  java
  • Falsk-信号

    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在其中添加数据时,自动触发

    执行顺序

    appcontext_pushed = _signals.signal('appcontext-pushed')
                request_started = _signals.signal('request-started')
    
                如果有render:
                    before_render_template = _signals.signal('before-render-template')
                    template_rendered = _signals.signal('template-rendered')
    
                request_finished = _signals.signal('request-finished')
    
                如果视图函数有异常:
                    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_popped = _signals.signal('appcontext-popped')
    
    
                如果使用信号:
                    message_flashed = _signals.signal('message-flashed')
    View Code

    使用

    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 "LOGIN"
    
    if __name__ == '__main__':
        app.run()

    信号与berfore_request()区别:

    信号:实时监控数据操作(记录日志) 
       在请求处理原来基础上添加额外操作 (信号比befors_request先执行)
    befors_requets:可以控制请求是否可以继续往下走(可以有返回值)
  • 相关阅读:
    C++ 黑白棋AI minimax+alphabeta剪枝
    BZOJ2839 集合计数 容斥
    BZOJ2287 消失之物
    CF235B Let's Play Osu! 期望DP
    线性基
    [HAOI2008]糖果传递 结论题
    [HAOI2007]上升序列
    线性筛及线性递推欧拉函数
    Codeforces 1064D/1063B Labyrinth
    洛谷P2120 [ZJOI2007]仓库建设 斜率优化DP
  • 原文地址:https://www.cnblogs.com/gpd-Amos/p/9041845.html
Copyright © 2011-2022 走看看