flask中请求勾子

请求勾子

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

  为了让每个视图函数避免编写重复功能的代码,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

原文地址:https://www.cnblogs.com/hongyizhang/p/10220499.html

时间: 2024-10-08 17:33:14

flask中请求勾子的相关文章

Flask中的请求钩子

请求勾子在客户端和服务器交互的过程中,有些准备工作或扫尾工作需要处理,比如: 在请求开始时,建立数据库连接: 在请求开始时,根据需求进行权限校验: 在请求结束时,指定数据的交互格式: 为了让每个视图函数避免编写重复功能的代码,Flask提供了通用设施的功能,即请求钩子. 请求钩子是通过装饰器的形式实现,Flask支持如下四种请求钩子: before_first_request 在处理第一个请求前执行 before_request 在每次请求前执行 如果在某修饰的函数中返回了一个响应,视图函数将不

Flask中的请求上下文和应用上下文

本文章粘贴自 https://blog.tonyseek.com/post/the-context-mechanism-of-flask/ 用过 Flask 做 Web 开发的同学应该不会不记得 App Context 和 Request Context 这两个名字--这两个 Context 算是 Flask 中比较特色的设计.[1] 从一个 Flask App 读入配置并启动开始,就进入了 App Context,在其中我们可以访问配置文件.打开资源文件.通过路由规则反向构造 URL.[2] 

Flask中处理依赖的技巧

Flask应用中通常会用工厂模式 来创建应用对象,这样方便配置和测试.现在我们就用实例来学习Flask的处理依赖 应用代码 # app/__init__.pyfrom flask import Flaskfrom flask_xxxext import Xxxfrom flask_yyyext import Yyy# ... 一些flask拓展xx = Xxx()yy = Yyy() def create_app(config=None): app = Flask(__name__) xx.in

Flask中全局变量的实现

我们都知道在Flask中g,request,session和request是作为全局对象来提供信息的,既然是全局的又如何保持线程安全呢,接下来我们就看看flask是如何做到这点的.在源码中的ctx.py中有AppContext和RequestContext两个类,他们分别管理应用上下文和请求上下文.两者的实现也差不多,这里我们看看AppContext的实现 class AppContext(object): """The application context binds a

Flask 中 @app.before_request、@app.after_request 和 @app.teardown_request

Flask 中 @app.before_request.@app.after_request 和 @app.teardown_request flask中又两种 context(上下文),分别是 application context 和 request context. 其中 request 就是 request context.当 HTTP 请求过来的时候,进入这个上下文. 题主的那些方法都是一些 flaks 的 hooks.用于针对 request 做一些操作,比如 before_requ

flask中的wtforms使用

一.简单介绍flask中的wtforms WTForms是一个支持多个web框架的form组件,主要用于对用户请求数据进行验证. 安装: pip3 install wtforms 二.简单使用wtforms组件 1.用户登录 具体代码: from flask import Flask,render_template,request,redirect from wtforms.fields import core from wtforms.fields import html5 from wtfo

用flask开发个人博客(4)—— flask中4种全局变量

https://blog.csdn.net/hyman_c/article/details/53512109 一  current_app current_app代表当前的flask程序实例,使用时需要flask的程序上下文激活,我们以本专栏第一篇文章中写的test.py为例介绍下它的用法: 1.1 激活程序上下文 [python] view plain copy >>> from test import app >>> from flask import curren

Flask最强攻略 - 跟DragonFire学Flask - 第六篇 Flask 中内置的 Session

Flask中的Session非常的奇怪,他会将你的SessionID存放在客户端的Cookie中,使用起来也非常的奇怪 1. Flask 中 session 是需要 secret_key 的 from flask import session app = Flask(__name__) app.secret_key = "DragonFire" secret_key 实际上是用来加密字符串的,如果在实例化的app中没有 secret_key 那么开启session一定会抛异常的 2.

Flask最强攻略 - 跟DragonFire学Flask - 第七篇 Flask 中路由系统

Flask中的路由系统其实我们并不陌生了,从一开始到现在都一直在应用 @app.route("/",methods=["GET","POST"]) 为什么要这么用?其中的工作原理我们知道多少? 请关注跟DragonFire学Flask 之 路由系统 ,这里有你想要的答案 1. @app.route() 装饰器中的参数 如果不明白装饰器 点击这里 methods : 当前 url 地址,允许访问的请求方式 @app.route("/inf