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

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

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

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

before_first_request

功能:

  • 只在第一个请求之前调用,第一个请求之后不再调用。

作用:

  • 可以在里面进行一些初始化操作,比如:连接数据库

注意:

  • “第一次”不是指用户第一次发起请求,而是服务器第一次接收到请求。
# 被该装饰器装饰的函数会在第一次请求之前调用。
# 强调:第一次不是指用户第一次发起请求,而是服务器第一次接收到请求。
# 作用:可以在此方法内部做一些初始化操作,比如连接数据库
@app.before_first_request
def before_first_request():
print("before_first_request 被执行")

before_request

功能:

  • 在每次请求的之前调用

作用:

  • 可以获取用户的session信息
  • 可以做一些请求校验,如果请求的校验不成功,可以使用return不执行视图函数

注意点:

  • 使用了return ,响应的状态码就变成了200,如果用户输入不存在的路由,且校验不通过,将不会返回404
# 被该装饰装饰的函数会在每一次请求之前调用
# 作用:可以在这个请求中做一些请求校验,如果请求的校验不成功,直接return之后那么就不会执行视图函数
@app.before_request
def before_request():
print("before_request 被执行")

after_request

功能:

  • 在每次请求之后,且视图函数被成功执行完之后调用
  • 需要传入一个参数,这个参数实际上为服务器的响应对象,并返回一个新的Response对象或者直接返回接受到的Response 对象

作用:

  • 可以在此方法中对响应做最后一步统一的处理,比如修改headers信息
# 被该装饰器装饰的函数会在视图被成功执行完之后调用,并且会把视图函数return的数据当做参数传入
# 作用:可以在此方法中对响应做最后一步统一的处理,比如修改headers信息
@app.after_request
def after_request(resp):
print("after_request 被执行")
resp.headers["Content-Type"] = "application/json"
return resp

teardown_request

功能:

  • 在每次请求之后调,无论视图函数是否执行成功,均调用

作用:

  • 可以用来收集错误信息
# 被该装饰器装饰的函数无论每一次请求是否成功都会调用
# 会接受一个参数,若视图执行出错,参数是服务器出现的错误信息,反之,为None
# 作用:可以用来收集错误
@app.teardown_request
def teardown_request(error):
print("teardown_request 被执行")
if error:
print(F"错误URL:{request.url},错误原因:{error}")
return app

运行结果图:

 

根据运行结果, 可以得出钩子函数在一次请求中的执行顺序, 如下图:

附码:

钩子管理文件,文件名为 app_init.py

from flask import Flask, request

def create_app():
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 被执行") # 被该装饰器装饰的函数会在视图被成功执行完之后调用,并且会把视图函数return的数据当做参数传入
# 作用:可以在此方法中对响应做最后一步统一的处理,比如修改headers信息
@app.after_request
def after_request(resp):
print("after_request 被执行")
resp.headers["Content-Type"] = "application/json"
return resp # 被该装饰器装饰的函数无论每一次请求是否成功都会调用
# 会接受一个参数,若视图执行出错,参数是服务器出现的错误信息,反之,为None
# 作用:可以用来收集错误
@app.teardown_request
def teardown_request(error):
print("teardown_request 被执行")
if error:
print(F"错误URL:{request.url},错误原因:{error}")
return app

视图函数文件

# 请求钩子在 app_init.py 中被定义
from app_init import create_app app = create_app() @app.route("/login/")
def login():
print("login视图被执行")
return "登录成功" @app.route("/create/")
def create():
print("create视图被执行")
return "创建成功" @app.route("/error/")
def error():
print("error视图被执行")
a = 1/0
return "ok" if __name__ == '__main__':
app.run()

参考:

https://blog.csdn.net/dakengbi/article/details/94437972

https://blog.csdn.net/f704084109/article/details/80932126

Flask_请求钩子(七)的更多相关文章

  1. 02 flask 请求钩子、异常捕获、上下文、Flask-Script 扩展、jinja2 模板引擎、csrf防范

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

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

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

  3. flask请求钩子、HTTP响应、响应报文、重定向、手动返回错误码、修改MIME类型、jsonify()方法

    请求钩子: 当我们需要对请求进行预处理和后处理时,就可以用Flask提供的回调函数(钩子),他们可用来注册在请求处理的不同阶段执行的处理函数.这些请求钩子使用装饰器实现,通过程序实例app调用,以 b ...

  4. Flask--四种请求钩子函数

    请求钩子函数:请求前,请求后需要做的处理 @app.before_first_request-在第一次请求之前执行 @app.before_request-在每一次请求之前执行 @app.after_ ...

  5. flask基础之请求钩子(十二)

    前言 什么是请求钩子?在客户端和服务器交互的过程中,有些准备工作或扫尾工作需要统一处理,为了让每个视图函数避免编写重复功能的代码,flask提供了统一的接口可以添加这些处理函数,即请求钩子. 请求钩子 ...

  6. falsk 请求钩子

    请求钩子是通过装饰器的形式实现,Flask支持如下四种请求钩子:before_first_request在处理第一个请求前执行before_request在每次请求前执行如果在某修饰的函数中返回了一个 ...

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

    一.上下文 请求上下文:request与session 应用上下文:current_app与g:一次请求多个函数可以用它传参 @app.route("/") def index() ...

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

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

  9. Flask的请求钩子与上下文简览

    请求钩子(Hook) 在客户端和服务器交互的过程中,有些准备工作或扫尾工作需要处理,比如:在请求开始时,建立数据库连接:在请求结束时,指定数据的交互格式.为了让>每个视图函数避免编写重复功能的代 ...

随机推荐

  1. javascript将平行的拥有上下级关系的数据转换成树形结构

    转换函数 var Littlehow = {}; /** * littlehow 2019-05-15 * 平行数据树形转换器 * @type {{format: tree.format, sort: ...

  2. SSO(单点登录)示例

    此文为转载文章,出处:https://www.cnblogs.com/jpfss/p/9273680.html SSO在我们的应用中非常常见,例如我们在OA系统登录了,我们就可以直接进入采购系统,不需 ...

  3. CentOs 7 yum 安装Nginx

    打开官网下载文档:http://nginx.org/en/download.html 2进入操作系统 centOs 7,建立文件夹 nginx ,进入nginx ,拷贝 上图1编辑命令:/etc/yu ...

  4. [笔记] encoder-decoder NEURAL MACHINE TRANSLATION BY JOINTLY LEARNING TO ALIGN AND TRANSLATE

    原文地址 :[1409.0473] Neural Machine Translation by Jointly Learning to Align and Translate (arxiv.org) ...

  5. QPS和TPS的区别于理解

    TPS: (每秒事务处理量(TransactionPerSecond)) 一个表达系统处理能力的性能指标,每秒处理的消息数(Transaction Per Second),每秒事务处理量 - 性能测试 ...

  6. DevOps的分与合

    一.抽象的 DevOps DevOps 是使软件开发和 IT 团队之间的流程自动化的一组实践,以便他们可以更快,更可靠地构建,测试和发布软件.DevOps 的概念建立在建立团队之间协作文化的基础上,这 ...

  7. nodejs+koa+uniapp实现微信小程序登陆获取用户手机号及openId

    nodejs+koa+uniapp实现微信小程序登陆获取用户手机号及openId 前言: 我准备用nodejs+koa+uniapp实现一款餐饮点单小程序,以及nodejs+koa+vue实现后端管理 ...

  8. CF1106A Lunar New Year and Cross Counting 题解

    Content 试求出在一个 \(n\times n\) 的地图 \(M\) 中,满足 \(1\leqslant i,j\leqslant n\) 且 \(M_{i,j}=M_{i+1,j+1}=M_ ...

  9. Linux使用docker安装RabbitMQ

    拉取镜像 docker pull rabbitmq:management 启动容器 docker run -d --name rabbitmq -e RABBITMQ_DEFAULT_USER=adm ...

  10. c++关于使用new的纠正

    自己之前纠正过这个问题,但还是忘了.今天再拿出来. 今天主要总结关于使用 c++ 标准中的 new 关键字. [结论] A.处理new可能抛出的异常 B.针对new使用std::nothrow不抛出异 ...