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

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

为了让每个视图函数避免编写重复功能的代码,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. HTTP协议及常见状态码

    超文本传输协议(HTTP)是用于传输诸如HTML的超媒体文档的应用层协议.它被设计用于Web浏览器和Web服务器之间的通信,但它也可以用于其他目的. HTTP遵循经典的客户端-服务端模型,客户端打开一 ...

  2. 基于spring sringmvc mybatis 做的导入导出

    导入 pom.xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://ww ...

  3. Nginx结构原理全解析

    目录 一.Nginx简单介绍 二.Nginx优势 IO多路复用epoll模型 轻量级 Nginx的基本功能 .Nginx应用场景 Nginx代理 三.Nginx的结构解析 进程操作 事件模型 事件处理 ...

  4. 手把手教你提交Jar包到Maven公共仓库 | 萌新写开源02

    在上一篇文章中,我介绍了自己的SpringBoot Starter项目,可以让我们使用注解的方式轻松地获取操作日志,并推送到指定数据源. 之前,我的项目开源在Github上,大家想要用我的项目,还得把 ...

  5. heap exploit about ptmalloc in glibc version 2.31

    学习的一下高版本的libc的利用方式. 项目地址:https://github.com/StarCross-Tech/heap_exploit_2.31 tcache_dup 源代码: 1 #incl ...

  6. HGAME2021 week3 pwn writeup

    一共放出五道题,都不是很难. blackgive 考栈转移,值得注意的一点是转移过去先填充几个ret,因为如果直接在转移过去的地方写rop链,执行起来会覆盖到上面的一些指针,导致程序不能正常输入和输出 ...

  7. CF918B Radio Station 题解

    Content 有 \(n\) 个形如 \(a_i.b_i.c_i.d_i\) 的 IP 地址.有 \(m\) 条命令,每条命令由一条字符串 \(s\) 和一个形如 \(p.q.r.s\) 的 IP ...

  8. Docker容器自动更新

    前言: Watchtower 是一个可以实现自动化更新 Docker 基础镜像与容器的实用工具.它监视正在运行的容器以及相关的镜像,当检测到reg­istry中的镜像与本地的镜像有差异时,它会拉取最新 ...

  9. sar命令查看网卡流量 (System ActivityReporter系统活动情况报告)

    sar命令查看网卡流量 2016年06月14日 03:31:29 WarriorTan 阅读数:9748更多 个人分类: Linux   版权声明:本文为博主原创文章,未经博主允许不得转载. http ...

  10. C++ 11新特性:std::future & std::shared_future) (转载)

    上一讲<C++11 并发指南四(<future> 详解二 std::packaged_task 介绍)>主要介绍了 <future> 头文件中的 std::pack ...