Flask的 preprocess_request
理解 Flask 类似框架中的 preprocess_request
方法
在 Flask 类似的 web 框架中,preprocess_request
方法是一个关键组件。它在请求被分派之前调用,用于执行一些预处理操作。让我们一步一步来理解这个方法的工作原理。
1. 方法概述
首先,我们来看看方法的注释部分,它概述了方法的主要功能:
def preprocess_request(self):"""Called before the request is dispatched. Calls:attr:url_value_preprocessors registered with the app and thecurrent blueprint (if any). Then calls :attr:before_request_funcsregistered with the app and the blueprint.If any :meth:before_request handler returns a non-None value, thevalue is handled as if it was the return value from the view, andfurther request handling is stopped."""
1.1 注释解释
- 作用: 在请求被分派之前调用。
- url_value_preprocessors: 这些是与应用程序和当前蓝图(如果有的话)注册的预处理函数。
- before_request_funcs: 这些是与应用程序和蓝图注册的在请求之前调用的函数。
- 返回值处理: 如果任何
before_request
处理器返回非None
值,这个值将作为视图的返回值处理,并且后续的请求处理将被停止。
2. 方法实现
现在,让我们详细了解方法的实现部分:
bp = _request_ctx_stack.top.request.blueprint
2.1 获取当前请求的蓝图
- _request_ctx_stack.top.request.blueprint: 获取当前请求上下文中的蓝图。这是通过访问
_request_ctx_stack
顶部的请求对象来实现的。
funcs = self.url_value_preprocessors.get(None, ())
if bp is not None and bp in self.url_value_preprocessors:funcs = chain(funcs, self.url_value_preprocessors[bp])
for func in funcs:func(request.endpoint, request.view_args)
2.2 调用 URL 值预处理器
- url_value_preprocessors.get(None, ()): 获取与应用程序注册的全局 URL 值预处理器。
- 检查蓝图: 如果当前请求有蓝图且在
url_value_preprocessors
中注册过,则获取该蓝图的预处理器,并将其与全局预处理器链在一起。 - 执行预处理器: 对每个预处理器函数调用
func(request.endpoint, request.view_args)
,其中request.endpoint
是请求的端点,request.view_args
是视图参数。
funcs = self.before_request_funcs.get(None, ())
if bp is not None and bp in self.before_request_funcs:funcs = chain(funcs, self.before_request_funcs[bp])
for func in funcs:rv = func()if rv is not None:return rv
2.3 调用请求前函数
- before_request_funcs.get(None, ()): 获取与应用程序注册的全局请求前函数。
- 检查蓝图: 如果当前请求有蓝图且在
before_request_funcs
中注册过,则获取该蓝图的请求前函数,并将其与全局函数链在一起。 - 执行请求前函数: 对每个请求前函数调用
func()
,如果返回值rv
不是None
,则直接返回该值并停止后续处理。
3. 代码示例
下面是一个实际的代码示例,演示如何在 Flask 中使用 preprocess_request
方法。我们将创建一个简单的 Flask 应用,并在其中注册 URL 值预处理器和请求前函数,以展示 preprocess_request
的实际用法。
我们创建一个简单的 Flask 应用,并添加 URL 值预处理器和请求前函数。
from flask import Flask, request, g, _request_ctx_stackapp = Flask(__name__)# URL 值预处理器
@app.url_value_preprocessor
def add_user_id(endpoint, values):if values is not None and 'user_id' in values:g.user_id = values.pop('user_id')# 请求前函数
@app.before_request
def authenticate():user_id = getattr(g, 'user_id', None)if user_id is None:return "User ID is missing", 400# 在这里可以添加实际的认证逻辑if user_id != '42':return "Unauthorized", 403# 示例视图函数
@app.route('/user/<user_id>')
def get_user_profile(user_id):return f"User Profile of {user_id}"# 运行应用
if __name__ == '__main__':app.run(debug=True)
3.1. 代码解释
3.1.1 URL 值预处理器
@app.url_value_preprocessor
def add_user_id(endpoint, values):if values is not None and 'user_id' in values:g.user_id = values.pop('user_id')
- 功能: 这个预处理器在请求的 URL 中包含
user_id
时,将其存储到 Flask 的全局对象g
中,以便在请求的其他部分使用。
3.1.2 请求前函数
@app.before_request
def authenticate():user_id = getattr(g, 'user_id', None)if user_id is None:return "User ID is missing", 400# 在这里可以添加实际的认证逻辑if user_id != '42':return "Unauthorized", 403
- 功能: 这个请求前函数在每次请求前执行,用于检查
g
对象中是否存在user_id
。如果不存在,则返回错误。如果user_id
不等于'42'
,则返回未授权错误。
3.1.3 示例视图函数
@app.route('/user/<user_id>')
def get_user_profile(user_id):return f"User Profile of {user_id}"
- 功能: 这是一个示例视图函数,根据 URL 中的
user_id
返回用户的个人资料。在这个例子中,实际上只是返回一个包含user_id
的字符串。
3.1.4. 运行应用
运行应用后,可以通过以下 URL 测试不同的情况:
- 正常请求:
http://127.0.0.1:5000/user/42
,应返回User Profile of 42
。 - 缺少
user_id
:http://127.0.0.1:5000/user/
,应返回User ID is missing
。 - 未授权请求:
http://127.0.0.1:5000/user/43
,应返回Unauthorized
。
通过这个示例代码,我们展示了如何使用 Flask 的 preprocess_request
方法来进行请求预处理。这种预处理机制在实际应用中非常有用,可以用于各种任务,如请求参数验证、认证和授权等。
4. 结论
通过这个教程,我们详细了解了 preprocess_request
方法的工作机制。它在请求被处理之前,依次调用 URL 值预处理器和请求前函数,以便进行必要的预处理。如果任何请求前函数返回非 None
值,请求处理将立即停止,并返回该值作为响应。
这种机制允许开发者在请求处理的早期阶段进行各种预处理操作,例如验证请求参数、设置全局变量、执行权限检查等,从而提高应用程序的健壮性和安全性。
希望这个教程能够帮助你更好地理解和使用 Flask 类似框架中的 preprocess_request
方法。
相关文章:
Flask的 preprocess_request
理解 Flask 类似框架中的 preprocess_request 方法 在 Flask 类似的 web 框架中,preprocess_request 方法是一个关键组件。它在请求被分派之前调用,用于执行一些预处理操作。让我们一步一步来理解这个方法的工作原理。 1. 方法概述 首先,我…...
重温react-05(类组件生命周期和性能优化)
类组件的生命周期 import React, { Component } from reactexport default class learnReact05 extends Component {state {number: 1}render() {return (<div>{this.state.number}</div>)}// 一般将请求的方法,放在这个生命周期componentDidMount() {setInterva…...

RHCE四---web服务器的高级优化方案
一、Web服务器(2) 基于https协议的静态网站 概念解释 HTTPS(全称:Hyper Text Transfer Protocol over Secure Socket Layer 或 Hypertext TransferProtocol Secure,超文本传输安全协议),是以…...

Pytest集成Allure生成测试报告
# 运行并输出报告在Report文件夹下 查看生成的allure报告 1. 生成allure报告:pycharm terminal中输入命令:产生报告文件夹 pytest -s --alluredir../report 2. pycharm terminal中输入命令:查看生成的allure报告 allure serve ../report …...
SpringBoot 参数校验
参数校验 引入springvalidation依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-validation</artifactId> </dependency>参数前添加Pattern public Result registry(Pattern(regexp &qu…...

【Arduino】实验使用ESP32控制可编程继电器制作跑马灯(图文)
今天小飞鱼实验使用ESP控制继电器,为了更好的掌握继电器的使用方法这里实验做了一个跑马灯的效果。 这里用到的可编程继电器,起始原理并不复杂,同样需要ESP32控制针脚输出高电平或低电平给到继电器,继电器使用这个信号控制一个电…...

islower()方法——判断字符串是否全由小写字母组成
自学python如何成为大佬(目录):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm1001.2014.3001.5501 语法参考 islower()方法用于判断字符串是否由小写字母组成。islower()方法的语法格式如下: str.islower() 如果字符串中包含至少一个区…...
发布/订阅模式
实现发布/订阅模式的基本思路是通过一个中介者(发布者)来管理订阅者(监听器),并在特定事件发生时通知所有订阅者执行相应的操作。下面是实现发布/订阅模式的基本思路: 创建发布者对象:首先&…...
K8S Pod常见状态
这是自己所遇到 Pod 常见状态及可能原因,持续更新。 如有其他的错误状态,可私我更新 1. ImagePullBackOff 问题分析: 镜像拉取失败。 可能原因: 可能是网络问题导致,检查Pod所在节点是否能够正常访问网络; 镜…...

Hadoop3:Yarn常用Shell命令
一、查看任务 1、查看所有任务 yarn application -list2、根据状态查看任务 语法 yarn application -list -appStates (所有状态:ALL、NEW、NEW_SAVING、SUBMITTED、ACCEPTED、RUNNING、FINISHED、FAILED、KILLED)例如 yarn application…...

15.数据库简介+MySQl使用+SQL语句
文章目录 数据库简述一.数据库简介DB1.定义:2.DBMS数据库管理系统3.数据库分类 二.MySQL的安装1.安装步骤2.MySQL数据库图形管理工具3.mysql程序常用命令4.MySQL字符集及字符序5.Navicat快捷键操作 三.MySQL数据库基本操作 .........................................表管理一.…...

AI入门系列:工具篇之ChatGPT的优秀的国内替代品
文章目录 一,智谱清言(ChatGLM)1,智谱清言简介2,[智谱清言地址,点我开始用吧](https://chatglm.cn/) 二,Kimi智能助手1,Kimi简介2,[Kimi地址,点我开始用吧](https://kimi.moonshot.c…...

改机软件有哪些?实现一键新机、改串号、改IMEI和手机参数的需求 硬改手机软件,新机环境模拟 设备伪装,一键改机,一键复原
这次针对可以直接开端口修改参数的机型做一些工具解析 前面接触合作过很多工作室。其中很多工作室对于各自软件的跳验证有各自的需求。 一个机型各项参数一般有IMEI WiFi 蓝牙 sn psb ESN等等。 针对这些参数的修改首先要明白各自软件检测的具体是哪些参数来验证。 对于常用…...

如何快速使用JNI
文章目录 1_JNI是什么?2_使用3_扩展 1_JNI是什么? JNI 是Java Native Interface的缩写,通过JNI,允许Java代码与其他语言(通常是C或C)编写的本地应用程序或库进行交互。简而言之就是,Java可以通…...

simulink开发stm32,使用中断模块,无法产生中断,其中包括使用timer模块,以及ADC都无法产生中断,需要注意的地方
1,其中包括使用timer模块,以及ADC都无法产生中断,需要注意的地方 原来是需要在配置文件里开启一下timer的中断,其他模块自动加载ioc就可以了,这个timer需要注意力,需要自己勾选一下 如下图: 看…...
C# 如何单纯的优化循环
Parallel.For(0, 10000, i >{// 并行执行的代码块// 例如: Console.WriteLine(i);}); 这种循环比 单纯常用的for 和 foreach 要稍微快一点 但是呢如果循环里面写的是非常简单的业务逻辑 的话 for和foreach 要更胜一筹一点 Parallel 原理就好像我一个人忙不过来可以多找几个…...
【鸿蒙学习笔记】@Extend装饰器:定义扩展组件样式
官方文档:Extend装饰器:定义扩展组件样式 [Q&A] Extend装饰器 作用 Extend用于扩展原生组件样式。 [Q&A] Extend装饰器 特点 1・Extend仅支持在全局定义,不支持在组件内部定义。 2・Extend支持封装指定组件的…...

【Docker项目实战篇】Docker部署PDF多功能工具Stirling-PDF
【Docker项目实战篇】Docker部署PDF多功能工具Stirling-PDF 前言一、Stirling-PDF介绍1.1 Stirling-PDF简介1.2 Stirling-PDF功能 二、本次实践规划2.1 本地环境规划2.2 本次实践介绍 三、本地环境检查3.1 检查Docker服务状态3.2 检查Docker版本3.3 检查docker compose 版本 四…...

【算法训练记录——Day37】
Day37——贪心Ⅴ 1.leetcode_56合并区间 1.leetcode_56合并区间 思路:排序,如果重叠,更新right 为max(right, curVal), 不重叠就加入res,需要单独考虑最后一次,因为每次都是在下一次遍历开始时判断是否加入res,因此 当…...

OpenCV 张正友标定法(二)
文章目录 一、简介二、实现代码三、实现效果参考资料一、简介 在之前的博客OpenCV 张氏标定法中,我们没有考虑镜头畸变等因素,因此计算出的内参与外参均是理想情况下的数值,而如果我们考虑到镜头的畸变: 我们就需要考虑使用最小二乘法最小化像素坐标的重投影误差(上述所求…...

19c补丁后oracle属主变化,导致不能识别磁盘组
补丁后服务器重启,数据库再次无法启动 ORA01017: invalid username/password; logon denied Oracle 19c 在打上 19.23 或以上补丁版本后,存在与用户组权限相关的问题。具体表现为,Oracle 实例的运行用户(oracle)和集…...

树莓派超全系列教程文档--(61)树莓派摄像头高级使用方法
树莓派摄像头高级使用方法 配置通过调谐文件来调整相机行为 使用多个摄像头安装 libcam 和 rpicam-apps依赖关系开发包 文章来源: http://raspberry.dns8844.cn/documentation 原文网址 配置 大多数用例自动工作,无需更改相机配置。但是,一…...

大型活动交通拥堵治理的视觉算法应用
大型活动下智慧交通的视觉分析应用 一、背景与挑战 大型活动(如演唱会、马拉松赛事、高考中考等)期间,城市交通面临瞬时人流车流激增、传统摄像头模糊、交通拥堵识别滞后等问题。以演唱会为例,暖城商圈曾因观众集中离场导致周边…...

【HarmonyOS 5.0】DevEco Testing:鸿蒙应用质量保障的终极武器
——全方位测试解决方案与代码实战 一、工具定位与核心能力 DevEco Testing是HarmonyOS官方推出的一体化测试平台,覆盖应用全生命周期测试需求,主要提供五大核心能力: 测试类型检测目标关键指标功能体验基…...
Objective-C常用命名规范总结
【OC】常用命名规范总结 文章目录 【OC】常用命名规范总结1.类名(Class Name)2.协议名(Protocol Name)3.方法名(Method Name)4.属性名(Property Name)5.局部变量/实例变量(Local / Instance Variables&…...
Linux云原生安全:零信任架构与机密计算
Linux云原生安全:零信任架构与机密计算 构建坚不可摧的云原生防御体系 引言:云原生安全的范式革命 随着云原生技术的普及,安全边界正在从传统的网络边界向工作负载内部转移。Gartner预测,到2025年,零信任架构将成为超…...
Mobile ALOHA全身模仿学习
一、题目 Mobile ALOHA:通过低成本全身远程操作学习双手移动操作 传统模仿学习(Imitation Learning)缺点:聚焦与桌面操作,缺乏通用任务所需的移动性和灵活性 本论文优点:(1)在ALOHA…...
Xen Server服务器释放磁盘空间
disk.sh #!/bin/bashcd /run/sr-mount/e54f0646-ae11-0457-b64f-eba4673b824c # 全部虚拟机物理磁盘文件存储 a$(ls -l | awk {print $NF} | cut -d. -f1) # 使用中的虚拟机物理磁盘文件 b$(xe vm-disk-list --multiple | grep uuid | awk {print $NF})printf "%s\n"…...

技术栈RabbitMq的介绍和使用
目录 1. 什么是消息队列?2. 消息队列的优点3. RabbitMQ 消息队列概述4. RabbitMQ 安装5. Exchange 四种类型5.1 direct 精准匹配5.2 fanout 广播5.3 topic 正则匹配 6. RabbitMQ 队列模式6.1 简单队列模式6.2 工作队列模式6.3 发布/订阅模式6.4 路由模式6.5 主题模式…...

GO协程(Goroutine)问题总结
在使用Go语言来编写代码时,遇到的一些问题总结一下 [参考文档]:https://www.topgoer.com/%E5%B9%B6%E5%8F%91%E7%BC%96%E7%A8%8B/goroutine.html 1. main()函数默认的Goroutine 场景再现: 今天在看到这个教程的时候,在自己的电…...