以request为例,因为request最简单。
一个完整的app应用程序如下:
from flask import Flask
app = Flask(__name__)
@app.route("/")
def hello():
return "hello world"
if __name__ == "__main__":
app.__call__
app.run()
#app.run() 程序执行起来,内部执行了run_simple
#run_simple(host, port, self, **options)
#第三个参数是self,最后会执行__call__方法:
一、将请求相关的东西做了一次封装
flask类中:
app.run方法中:
其中self指的是app,run_simple会执行app.__call__方法:
flask中的__call__方法,调用了flask中的wsgi_app方法,该方法中执行了请求相关的所有操作:
1、首先执行了ctx = self.request_context(environ),其中environ是请求相关的所有数据
request_context方法实例化了一个 RequestContext对象,执行RequestContext类中__init__方法:
在RequestContext类的__init__方法,因为request是None,将执行app.request_class方法,其中app是Flask类的实例对象 ,在Flask类中可以看到,Flask将请求相关的操作又封装到了一个Request类中,RequestContext不仅包含请求,还包括session,flaskes等。
2、然后执行ctx.push()
ctx是RequestContext类的实例化对象,所以会执行RequestContext类中的push方法:
该方法中注意_request_ctx_stack.push(self),其中self是RequestContext对象,其中包含了请求相关的所有数据。
而_request_ctx_stack在globals.py中,是在程序刚开始运行时就创建的一个全局变量:
LocalStack里封装的Local对象:
LocalStack里的push方法会调用Local类的__setattr__,根据线程或协程唯一id将数据保存在各自的字典中: