flask框架(下)
创始人
2024-05-26 18:48:27
0

文章目录

  • flask框架(下)
    • werkzeug简介
    • 请求上下文
      • flask 处理方案
      • 回到 wsgi_app 方法中
      • push 源码
      • 总结
      • 补充

flask框架(下)

werkzeug简介

Werkzeug是一个WSGI工具包,他可以作为一个Web框架的底层库。这里稍微说一下, werkzeug 不是一个web服务器,也不是一个web框架,而是一个工具包,官方的介绍说是一个 WSGI 工具包,它可以作为一个 Web 框架的底层库,因为它封装好了很多 Web 框架的东西,例如 Request,Response 等等

通过 查看 flask.run() 源码可以发现,实际上执行的也是 werkzeug 下的 run_simlpe 函数

在这里插入图片描述

如下一个demo 可以看出 run_simple() 做了些什么

from werkzeug.serving import run_simple
from werkzeug.wrappers import Request, Response@Request.application
def app(req):print(req.method)    # GETprint(req.path)     # /return Response('200 ok')run_simple('0.0.0.0', 5000, app)

在这里插入图片描述

请求上下文

在django 中,每一个试图函数,都必需要接受一个request参数,才能执行试图函数,并且请求携带的参数也在request对象中,但是在flask 中,request 对象是一个全局对象,那么在多个请求过来时,flask是如何处理,才能在多线程条件下保证request对象携带参数是正确的?答案就在flask 的请求上下文管理中

flask 处理方案

入口还是在 app.run() 方法。

在 Flask 类中,可以发现重写的 __ call__ 方法。每当请求过来时,都会加括号执行app,因此都会自动执行__ call__方法。

在这里插入图片描述

继续往下,可以发现 wsgi_app 方法源码如下

在这里插入图片描述

继续往下,可以发现。request_context 实际上就是返回了 RequestContext 类的对象
在这里插入图片描述
在这里插入图片描述

回到 wsgi_app 方法中

在这里插入图片描述

push 源码

在这里插入图片描述
节约时间。下方直接 copy 参考博客截图。原文地址如下
_request_ctx_stack是LocalStack类的实例化对象:

在这里插入图片描述

LocalStack类中的__init__方法如下:
在这里插入图片描述

Local类的__init__方法如下:
在这里插入图片描述

get_ident是Local类所在文件中导入的一个方法名,该方法执行后会得到线程或协程ID,如下:
   在这里插入图片描述

LocalStack类中的top是一个属性方法,源码如下:
在这里插入图片描述

下一步Local类中的__getattr__方法源码如下:

在这里插入图片描述

到此,分析得出top = _request_ctx_stack.top中的top为None。

接下来分析 **_request_ctx_stack.push(self)**做了什么?LocalStack类中的push方法源码如下:

在这里插入图片描述

Local类中的__setattr__方法源码如下:

在这里插入图片描述

因为rv.append(obj),所以最后LocalStack对象,即_request_ctx_stack对象字典化后如下:

{'_local':{'__storage__':{9527:{stack:[ctx]}}, '__ident_func__':get_ident}}
# 说明:9527假设是获取到的线程或者协程号,ctx包含request对象和session对象。

到此,flask请求上文结束,也就是完成了将一个request和session对象存储到某个地方。

总结

1.  请求来时,flask 会把当次请求对象 request 放到 local 对象中,每个请求都是一个线程local对象实际管理的就是一个字典,里面以线程或者协程id为key,请求对象为value 值
2.  使用时,会根据 key 到 local 对象中取值,确保携带的值不会出错
3.  请求结束,flask 会把 该次 request 对象从local中移除
4.  g 对象和 session 也是采用上述相同处理。

补充

在阅读过程中发现,request对象,session和g对象都是同一个类 LocalProxy的对象,

在这里插入图片描述

LocalProxy类是个代理类, 重写了所有的魔法方法。来我们在使用时,request,session,g对象的属性打印出来的属性不一致。

相关内容

热门资讯

不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
安卓文字转语音tts没有声音 安卓文字转语音TTS没有声音的问题在应用中比较常见,通常是由于一些设置或者代码逻辑问题导致的。本文将...
APK正在安装,但应用程序列表... 这个问题可能是由于以下原因导致的:应用程序安装的APK文件可能存在问题。设备上已经存在同名的应用程序...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
报告实验.pdfbase.tt... 这个错误通常是由于找不到字体文件或者文件路径不正确导致的。以下是一些解决方法:确认字体文件是否存在:...