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 张氏标定法中,我们没有考虑镜头畸变等因素,因此计算出的内参与外参均是理想情况下的数值,而如果我们考虑到镜头的畸变: 我们就需要考虑使用最小二乘法最小化像素坐标的重投影误差(上述所求…...
UE5 学习系列(二)用户操作界面及介绍
这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…...
51c自动驾驶~合集58
我自己的原文哦~ https://blog.51cto.com/whaosoft/13967107 #CCA-Attention 全局池化局部保留,CCA-Attention为LLM长文本建模带来突破性进展 琶洲实验室、华南理工大学联合推出关键上下文感知注意力机制(CCA-Attention),…...
反向工程与模型迁移:打造未来商品详情API的可持续创新体系
在电商行业蓬勃发展的当下,商品详情API作为连接电商平台与开发者、商家及用户的关键纽带,其重要性日益凸显。传统商品详情API主要聚焦于商品基本信息(如名称、价格、库存等)的获取与展示,已难以满足市场对个性化、智能…...
前端导出带有合并单元格的列表
// 导出async function exportExcel(fileName "共识调整.xlsx") {// 所有数据const exportData await getAllMainData();// 表头内容let fitstTitleList [];const secondTitleList [];allColumns.value.forEach(column > {if (!column.children) {fitstTitleL…...
2.Vue编写一个app
1.src中重要的组成 1.1main.ts // 引入createApp用于创建应用 import { createApp } from "vue"; // 引用App根组件 import App from ./App.vue;createApp(App).mount(#app)1.2 App.vue 其中要写三种标签 <template> <!--html--> </template>…...
STM32标准库-DMA直接存储器存取
文章目录 一、DMA1.1简介1.2存储器映像1.3DMA框图1.4DMA基本结构1.5DMA请求1.6数据宽度与对齐1.7数据转运DMA1.8ADC扫描模式DMA 二、数据转运DMA2.1接线图2.2代码2.3相关API 一、DMA 1.1简介 DMA(Direct Memory Access)直接存储器存取 DMA可以提供外设…...
华为OD机试-食堂供餐-二分法
import java.util.Arrays; import java.util.Scanner;public class DemoTest3 {public static void main(String[] args) {Scanner in new Scanner(System.in);// 注意 hasNext 和 hasNextLine 的区别while (in.hasNextLine()) { // 注意 while 处理多个 caseint a in.nextIn…...
【论文阅读28】-CNN-BiLSTM-Attention-(2024)
本文把滑坡位移序列拆开、筛优质因子,再用 CNN-BiLSTM-Attention 来动态预测每个子序列,最后重构出总位移,预测效果超越传统模型。 文章目录 1 引言2 方法2.1 位移时间序列加性模型2.2 变分模态分解 (VMD) 具体步骤2.3.1 样本熵(S…...
Rapidio门铃消息FIFO溢出机制
关于RapidIO门铃消息FIFO的溢出机制及其与中断抖动的关系,以下是深入解析: 门铃FIFO溢出的本质 在RapidIO系统中,门铃消息FIFO是硬件控制器内部的缓冲区,用于临时存储接收到的门铃消息(Doorbell Message)。…...
什么是Ansible Jinja2
理解 Ansible Jinja2 模板 Ansible 是一款功能强大的开源自动化工具,可让您无缝地管理和配置系统。Ansible 的一大亮点是它使用 Jinja2 模板,允许您根据变量数据动态生成文件、配置设置和脚本。本文将向您介绍 Ansible 中的 Jinja2 模板,并通…...
