關(guān)于Flask 上下文詳細(xì)介紹

1、上下文概念
上下文,說白了就是所謂的語境,就是語言環(huán)境。比如單獨(dú)拎出來一篇文章的某一句話,我們可能不能理解它的意思,但是通過這句話所處的語言環(huán)境,再結(jié)合它前后的語句,就能很輕易的理解。
我們可以把上下文理解為當(dāng)前環(huán)境的快照,是一個(gè)用來保存狀態(tài)的對(duì)象。在代碼執(zhí)行的某個(gè)時(shí)刻,根據(jù)上下文的代碼邏輯,可以決定在當(dāng)前時(shí)刻下使用到的環(huán)境變量等。
2、Flask中的上下文
Flask 中有兩種上下文,應(yīng)用上下文(application context)和請(qǐng)求上下文(request context):
application:指的是調(diào)用app = Flask(__name__)創(chuàng)建的Flask對(duì)象request:指的是每次HTTP請(qǐng)求發(fā)生時(shí),在Flask對(duì)象內(nèi)部創(chuàng)建的Request對(duì)象
2.1請(qǐng)求上下文
在Flask中處理請(qǐng)求時(shí),應(yīng)用會(huì)生成“請(qǐng)求上下文”對(duì)象,保存當(dāng)前請(qǐng)求的相關(guān)數(shù)據(jù)信息,整個(gè)請(qǐng)求的處理過程,都會(huì)在這個(gè)上下文對(duì)象中進(jìn)行,保證請(qǐng)求的處理過程獨(dú)立不受干擾。
請(qǐng)求上下文對(duì)象有:request和session,下面以request為例具體講解。
在上篇文章Flask? 請(qǐng)求鉤子的實(shí)現(xiàn) 我們說過,在 Flask 中有四種常用的請(qǐng)求鉤子,分別是:before_first_request、before_request、after_request和teardown_request。
@app.before_first_request
def before_first_request():
print(request.url)
print('before_first_request')
@app.before_request
def before_request():
print(request.url)
print('before_request')
@app.after_request
def after_request(response):
print(request.url)
print('after_request')
return response
@app.teardown_request
def teardown_request(e):
print(request.url)
print('teardown_request')
@app.route('/test')
def test():
print(request.url)
return 'test'

通過請(qǐng)求我們發(fā)現(xiàn),在每個(gè)請(qǐng)求鉤子裝飾的處理函數(shù)中,我們都可以直接訪問 request 對(duì)象。而且,在其他普通函數(shù)內(nèi),無法訪問 request 對(duì)象,說明 request 對(duì)象并不是真正的全局變量,只是在請(qǐng)求上下文的生命周期內(nèi)可以訪問,離開了請(qǐng)求的生命周期,就無法訪問了。上面的請(qǐng)求鉤子裝飾的處理函數(shù),在請(qǐng)求處理的不同階段執(zhí)行,自然其內(nèi)部也可以訪問 request 對(duì)象。
2.2應(yīng)用上下文
上面說請(qǐng)求上下文是和請(qǐng)求相關(guān),請(qǐng)求上下文對(duì)象保存的是請(qǐng)求的相關(guān)數(shù)據(jù)信息,下面說一下應(yīng)用上下文,所謂應(yīng)用上下文,就是和當(dāng)前應(yīng)用相關(guān)的,應(yīng)用上下文對(duì)象是包含當(dāng)前應(yīng)用相關(guān)的信息。
應(yīng)用上下文對(duì)象有:current_app和g。
我們了解到,每個(gè)請(qǐng)求,都有一個(gè) request 對(duì)象和視圖函數(shù)對(duì)應(yīng),可以理解為當(dāng)前請(qǐng)求(current request), 而程序也會(huì)有多個(gè)實(shí)例的情況,為了能獲取對(duì)應(yīng)的程序?qū)嵗?,而不是固定的某一個(gè)程序?qū)嵗覀兙托枰褂?current_app變量。
from flask import Flask, current_app
app = Flask("tigeriaf_app")
@app.route('/')
def index():
return 'Hello, {}!'.format(current_app.name)
current_app是一個(gè)本地代理,它的類型是werkzeug.local.LocalProxy,它所代理的即是app對(duì)象,也就是說current_app == LocalProxy(app)。所以通過current_app.name可以獲取當(dāng)前應(yīng)用的名稱,也就是tigeriaf_app,使用current_app是因?yàn)樗彩且粋€(gè)ThreadLocal變量,對(duì)它的改動(dòng)不會(huì)影響到其他線程。我們可以通過current_app._get_current_object()方法來獲取app對(duì)象。也可以在current_app中存儲(chǔ)一些自定義的變量。
current_app只在請(qǐng)求線程內(nèi)存在,它的生命周期就是在應(yīng)用上下文里。離開了應(yīng)用上下文,current_app一樣無法使用。
g對(duì)象是 Flask 程序全局的一個(gè)臨時(shí)變量,充當(dāng)中間媒介的作用。我們可以通過它傳遞一些數(shù)據(jù),g保存的是當(dāng)前請(qǐng)求的全局變量,每次請(qǐng)求都會(huì)重設(shè)這個(gè)值,我們通常會(huì)使用它結(jié)合請(qǐng)求鉤子來保存每個(gè)請(qǐng)求處理前所需要的全局變量,比如當(dāng)前登入的用戶對(duì)象,數(shù)據(jù)庫連接等。 比如,使用g對(duì)象保存請(qǐng)求的 token,在視圖函數(shù)中就可以直接使用g.name獲取對(duì)應(yīng)的值了。
from flask import g
@app.before_request
def get_token():
g.name = request.headers.get("token")
到此這篇關(guān)于 關(guān)于Flask 上下文詳細(xì)介紹的文章就介紹到這了,更多相關(guān)Flask 上下文內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決Alexnet訓(xùn)練模型在每個(gè)epoch中準(zhǔn)確率和loss都會(huì)一升一降問題
這篇文章主要介紹了解決Alexnet訓(xùn)練模型在每個(gè)epoch中準(zhǔn)確率和loss都會(huì)一升一降問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-06-06
一篇文章帶你搞定Ubuntu中打開Pycharm總是卡頓崩潰
這篇文章主要介紹了一篇文章帶你搞定Ubuntu中打開Pycharm總是卡頓崩潰,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
python實(shí)現(xiàn)zip分卷壓縮的詳細(xì)方法
WinHex 開始16進(jìn)制一個(gè)一個(gè)文件對(duì)比 WinRar 創(chuàng)建的分卷壓縮和單個(gè) zip 文件的差異,這篇文章主要介紹了python實(shí)現(xiàn)zip分卷壓縮的詳細(xì)方法,需要的朋友可以參考下2024-02-02
利用Python代碼實(shí)現(xiàn)模擬動(dòng)態(tài)指針時(shí)鐘
這篇文章主要為大家詳細(xì)介紹了如何利用python和C++代碼實(shí)現(xiàn)模擬動(dòng)態(tài)指針時(shí)鐘,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起了解一下2023-04-04
解決Python中由于logging模塊誤用導(dǎo)致的內(nèi)存泄露
這篇文章主要介紹了解決Python中由于logging模塊誤用導(dǎo)致的內(nèi)存泄露,針對(duì)由于過多的UDP連接所產(chǎn)生的問題,需要的朋友可以參考下2015-04-04

