请求勾子

  在客户端和服务器交互的过程中,有些准备工作或扫尾工作需要处理,比如:
    *在请求开始时,建立数据库连接;
    *在请求开始时,根据需求进行权限校验;
    *在请求结束时,指定数据的交互格式;

  为了让每个视图函数避免编写重复功能的代码,Flask提供了通用设施的功能,即请求钩子。

  请求钩子是通过装饰器的形式实现,Flask支持如下四种请求钩子:
    ①before_first_request
      在处理第一个请求前执行
    ②before_request
      在每次请求前执行
      如果在某修饰的函数中返回了一个响应,视图函数将不再被调用
    ③after_request
      如果没有抛出错误,在每次请求后执行
      接受一个参数:视图函数作出的响应
      在此函数中可以对响应值在返回之前做最后一步修改处理
      需要将参数中的响应在此参数中进行返回

      例如设置csrf_token可以在请求后设置在response里。
    ④teardown_request:
      在每次请求后执行
      接受一个参数:错误信息,如果有相关错误抛出

  代码测试:

      from flask import Flask

      from flask import abort

      app = Flask(__name__)
      

      # 在第一次请求之前调用,可以在此方法内部做一些初始化操作
      @app.before_first_request
      def before_first_request():
        print("before_first_request")
      

      # 在每一次请求之前调用,这时候已经有请求了,可能在这个方法里面做请求的校验
      # 如果请求的校验不成功,可以直接在此方法中进行响应,直接return之后那么就不会执行视图函数
      @app.before_request
      def before_request():
        print("before_request")

      

      # 在执行完视图函数之后会调用,并且会把视图函数所生成的响应传入,可以在此方法中对响应做最后一步统一的处理

      @app.after_request
      def after_request(response):
        print("after_request")
        response.headers["Content-Type"] = "application/json"

        return response

      # 请每一次请求之后都会调用,会接受一个参数,参数是服务器出现的错误信息
      @app.teardown_request
      def teardown_request(e):
        print("teardown_request")

      @app.route('/')
      def index():
        return 'index'

      if __name__ == '__main__':
        app.run(debug=True)

    在第1次请求时的打印:

      before_first_request

      before_request
      after_request
      teardown_request

    在第2次请求时的打印

    before_request

    after_request

    teardown_request

flask中请求勾子的更多相关文章

  1. Flask中请求数据的优雅传递

    当一个请求到来时,浏览器会携带很多信息发送发送服务端.在Django中,每一个处理函数都要传入一个request的参数,该参数携带所有请求的信息,也就是服务端程序封装的environ(不明白该参数可以 ...

  2. Flask 中请求钩子的理解和应用?

    请求钩子是通过装饰器的形式实现的,支持以下四种:1,before_first_request 在处理第一个请求前运行2,before_request:在每次请求前运行3,after_request:如 ...

  3. Flask中路由参数

    Flask中路由参数.请求方式设置 一.参数设置 1.参数类型 Flask中参数的使用 @app.route('/parames/<username>/') def hello_world ...

  4. Flask中本地栈的使用

    4种上下文变量 承接上一篇内容.当一个请求到来时,除了request被封装成全局变量之外,还有三个变量也是同样被封装成全局变量,那就是current_app.g.session.上面4个变量之所以能够 ...

  5. (三)flask中的请求钩子函数

    请求勾子 在客户端和服务器交互的过程中,有些准备工作或扫尾工作需要处理,比如: 在请求开始时,建立数据库连接: 在请求开始时,根据需求进行权限校验: 在请求结束时,指定数据的交互格式: 为了让每个视图 ...

  6. Flask基础(09)-->请求勾子函数

    什么是请求勾子? 为了让每个视图函数避免编写重复的功能代码,flask提供了通用设施的功能,就是所谓的勾子 那么请求勾子就是,在浏览器请求服务器资源的前后挂载相关的处理函数 请求勾子有什么作用? 作用 ...

  7. Python直接改变实例化对象的列表属性的值 导致在flask中接口多次请求报错

    错误原理实例如下: class One(): list = [1, 2, 3] @classmethod def get_copy_list(cls): # copy一份list,这样对list的改变 ...

  8. flask中的上下文_请求上下文和应用上下文

    前引 在了解flask上下文管理机制之前,先来一波必知必会的知识点. 面向对象双下方法 首先,先来聊一聊面向对象中的一些特殊的双下划线方法,比如__call__.__getattr__系列.__get ...

  9. Flask中获取参数(路径,查询,请求体,请求头)

    上一篇中已经讲述了:HTTP协议向服务器传参有几种途径{ 链接 } 在Flask中同样通过这4中传参途径进行归纳: 1. URL中路径参数的获取: 拓展: # 路由参数/路径参数:http://127 ...

随机推荐

  1. C#字节流通信格式

    类似通信格式的实现关键点: byte数组转float的实现,BitConvetor.toSingle() float类型转by,BitConverter.GetBytes #客户端发送public b ...

  2. Redis(二):c#连接Redis

    1.nuget StackExchange.Redis 2.建立RedisHelper类: public class RedisHelper { /// <summary> /// 连接字 ...

  3. 查看oracle 11g数据库用户的密码是否区分大小写

    用sys用户sqlplus连接到数据: SQL*Plus: Release 11.2.0.3.0 Production on Thu Jun 22 11:07:58 2017 Copyright (c ...

  4. 沉淀,再出发:jQuery的初步了解和入门

    沉淀,再出发:jQuery的初步了解和入门 一.前言     对于后端开发者来说,是不是真的不需要了解前端的开发经过和相关技术,从我个人的角度来说,我觉得如果不了解或者接触很少,极有可能造成开发的时候 ...

  5. centos7 docker 使用pipework 做虚拟机

    网卡配置文件 及 bridge的静态配置 centos7 Bridge配置 [root@mon-1 ~]# cd  /etc/sysconfig/network-scripts/ [root@mon- ...

  6. Apache,php配置

    很多朋友想要在window下配置apache+php+mysql运行环境,其实从这么长时间的经验来看,win2003下还是用iis,如果为了学习或对apache特别熟悉的朋友可以用apache   一 ...

  7. MD5随机盐值生成法

    public class Test3 { /** * 生成含有随机盐的密码 */ public static String generate(String password) { Random r = ...

  8. Java虚拟机10:Client模式和Server模式的区别

    部分商用虚拟机中,Java程序最初是通过解释器对.class文件进行解释执行的,当虚拟机发现某个方法或代码块运行地特别频繁的时候,就会把这些代码认定为热点代码Hot Spot Code(这也是我们使用 ...

  9. POJ3384 Feng Shui

    嘟嘟嘟 昨天我看到的这道题,今天终于A了. 写这道题的时间其实并不长,主要是我为这题现学了一个半平面相交(虽然是\(O(n ^ 2)\)的--) 思路说难也不难,关键是第一步的转化得想到. 首先可以肯 ...

  10. 32、SpringBoot-整合Dubbo

    分布式应用 在分布式系统中,国内常用zookeeper+dubbo组合,而Spring Boot推荐使用全栈的Spring, Spring Boot+Spring Cloud. 分布式系统: Zook ...