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

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

为了让每个视图函数避免编写重复功能的代码,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. springboot-MVC 过滤器使用

    一.前言 一下代码以SSO用户登录列子代码.完整代码https://gitee.com/xuxueli0323/xxl-sso 二.使用 2.1 创建过滤器 创建一个过滤器,实现Filter 接口 p ...

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

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

  3. 使用OPC与PLC通讯 一

    总结自己在opc与自控开发的经验.首先介绍OPC DA模式下的OPC各种操作. 在使用opc时需要引用到 OPCDAAuto.dll 这个类库. 在项目引用后需要注册这个类库,否则程序跑起来会报错,& ...

  4. Nginx安全检查

    1.检查是否配置Nginx账号锁定策略 描述 1.执行系统命令passwd -S nginx来查看锁定状态 出现Password locked证明锁定成功 如:nginx LK ..... (Pass ...

  5. vue-cli4结合element-ui异常解决(前端小白,文摘取自网络)

    1:将vue-cli4版本退回到vue-cli3 2:使用element-plus 替换 element-ui 传送门 => https://element-plus.gitee.io/#/zh ...

  6. thinkPhp不为空查询

    $filter['查询的字段']=array('NEQ',' ');注意:引号里是一个空格 也可以$filter['查询的字段']=array('exp','is not null'); ->w ...

  7. View的简单说明

    一)三个结构体:CGPoint.CGSize.CGRect 1. CGPoint struct CGPoint { CGFloat x; CGFloat y; }; typedef struct CG ...

  8. java多线程7:ReentrantReadWriteLock

    真实的多线程业务开发中,最常用到的逻辑就是数据的读写,ReentrantLock虽然具有完全互斥排他的效果(即同一时间只有一个线程正在执行lock后面的任务), 这样做虽然保证了实例变量的线程安全性, ...

  9. 搭建ELK日志平台(单机)

    系统版本:Ubuntu 16.04.7 LTS 软件架构:Filebeat+Kafka+Logstash+Elasticsearch+Kibana+Nginx 软件版本:Filebeat-7.16.0 ...

  10. Django查询结果以时间正序或者倒序排列

    正序 time1 = details.objects.all().order_by('time') 倒序 time2 = details.objects.all().order_by('-time')