Flask中的请求钩子

请求勾子
在客户端和服务器交互的过程中,有些准备工作或扫尾工作需要处理,比如:

                    在请求开始时,建立数据库连接;
                    在请求开始时,根据需求进行权限校验;
                    在请求结束时,指定数据的交互格式;

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

请求钩子是通过装饰器的形式实现,Flask支持如下四种请求钩子:

                before_first_request
                            在处理第一个请求前执行
                before_request
                            在每次请求前执行
                            如果在某修饰的函数中返回了一个响应,视图函数将不再被调用
                after_request
                            如果没有抛出错误,在每次请求后执行
                            接受一个参数:视图函数作出的响应

                            在此函数中可以对响应值在返回之前做最后一步修改处理
                            需要将参数中的响应在此参数中进行返回
            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")
    # if 请求不符合条件:
    #     return "laowang"

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

原文地址:http://blog.51cto.com/13914991/2172881

时间: 2024-10-08 17:24:56

Flask中的请求钩子的相关文章

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] 

python web开发-flask中访问请求数据request

Request对象在web应用的开发中是一个非常重要的对象,主要用来获取用户发来的请求数据. 常用属性参考:http://docs.jinkan.org/docs/flask/api.html#flask.request 下面我们以一个表单提交的例子来说明一些常用request属性的使用. 1. 创建一个表单的template 在templates文件夹下面创建form.html模板文件,输入下面的代码 {% extends "base.html" %} {% import "

用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中请求勾子

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

Flask框架之异常处理和请求钩子

异常处理 抛出异常 在Flask框架中,我们使用abort()方法,抛出异常信息. 代码如下: from flask import abort # 抛出异常 @app.route('/error') def error(): return abort(404) 捕获和处理异常 在Flask框架中,我们使用@app.errorhandler()装饰器,实现异常的捕获和处理. 代码如下: # 捕获异常 @app.errorhandler(404) def error_action(e): # 必须接

Flask之请求钩子

什么是请求钩子?说白了,就是在执行视图函数前后你可以进行一些处理,Flask使用装饰器为我们提供了注册通用函数的功能. before_first_request:在处理第一个请求前执行 before_request:在每次请求前执行 after_request:每次请求之后调用,前提是没有未处理的异常抛出 teardown_request:每次请求之后调用,即使有未处理的异常抛出 from flask import Flask app = Flask(__name__) @app.before_

Flask框架 之上下文、请求钩子与Flask_Script

一.上下文 请求上下文:request与session 应用上下文:current_app与g:一次请求多个函数可以用它传参 @app.route("/") def index(): g.username = "yy" test() return "page" # 1.请求上下文:request与session # 2.应用上下文:current_app与g:一次请求多个函数可以用它传参 def test(): print(g.username)

flask请求钩子

请求钩子 作用: 可以 对请求的事件进?行行监听 , ?方便便开发者对请求的各阶段进?行行?一些?自定义处理理 before_request和after_request before_first_request和teardown_request 原文地址:https://www.cnblogs.com/oklizz/p/11370193.html

2.5.3、请求钩子

有时在处理请求之前或之后执行代码会很有用.例如,在请求开始时,我们可能需要创建数据库连接或者认证发起请求的用户.为了避免在每个视图函数中都使用重复的代码,Flask 提供了注册通用函数的功能,注册的函数可在请求被分发到视图函数之前或之后 调用. 请求钩子使用修饰器实现.Flask 支持以下 4 种钩子. ?before_first_request:注册一个函数,在处理第一个请求之前运行. ?before_request:注册一个函数,在每次请求之前运行. ?after_request:注册一个函