Flask找上下文源码

1. app = Flask(name)

app.call

1.1 按住 command 键 点击 进到这个函数里

1.2 接着找 return 看看返回什么 点进去

1.3 找到定义函数

1.4 点进去先看这个里边有啥

1.5 找到定义类

1.6 找到RequestContext 类

1.7 找到 RequestContext ---> 的push 方法

1.8 点击 _cv_request 找到 globals.py 下的 _cv_request栈

2. 在wsgi的push方法中

2.1 进到push 方法

2.2 进到 app_context

2.3 进到APPContext

2.4 在ctx.py下 找到AppContext 类

2.5 找到AppContext --> 的push 方法

2.6 点击 _cv_app ---> 找到 globals.py 下的 _cv_app栈

3. 找到 --> APPContext --> RequestContext

3.1 进到LocalProxy

栈入口

栈的入口可以理解为:

应用上下文入口:当 app_ctx.push() 被调用时,应用上下文被推入栈。

请求上下文入口:当 _cv_request.set(self) 被调用时,当前请求上下文被推入栈。

栈退出

栈的退出通常在 pop() 方法中处理。Flask 在每个请求完成时,会自动调用请求上下文和应用上下文的弹出逻辑。

相关推荐
久美子1 小时前
Qoder 使用指南:从配置到落地
后端
tyung1 小时前
Go 手写 Wait-Free MPSC 无界队列:SwapPointer 实现多生产者无锁入队
后端·go
张不才1 小时前
CPU 100% 了怎么办?Java 性能排障的标准化操作
java·后端
鱼人1 小时前
Redis、网关负载均衡为什么不能用普通取模哈希?
后端
juejin9982 小时前
Claude Code Lab-3(下):三能力 MCP Server
后端
java小白小2 小时前
SpringBoot(07):事务管理——@Transactional 你真的用对了吗?
后端
shepherd1112 小时前
吞吐量提升 10 倍:高并发大批量数据处理任务的架构演进与性能调优
java·后端·架构
java小白小3 小时前
SpringBoot(05):Spring Data JPA——用面向对象的方式操作数据库
后端
juejin9983 小时前
Claude Code Lab-2(上):自然语言查库助手
后端
java小白小3 小时前
SpringBoot(06):多数据源配置——一个项目连多个库怎么做
后端