您好,登錄后才能下訂單哦!
本篇內(nèi)容介紹了“Flask上下文舉例分析”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!
上下文,說白了就是所謂的語境,就是語言環(huán)境。比如單獨拎出來一篇文章的某一句話,我們可能不能理解它的意思,但是通過這句話所處的語言環(huán)境,再結(jié)合它前后的語句,就能很輕易的理解。
我們可以把上下文理解為當(dāng)前環(huán)境的快照,是一個用來保存狀態(tài)的對象。在代碼執(zhí)行的某個時刻,根據(jù)上下文的代碼邏輯,可以決定在當(dāng)前時刻下使用到的環(huán)境變量等。
Flask
中有兩種上下文,應(yīng)用上下文(application context
)和請求上下文(request context
):
application
:指的是調(diào)用app = Flask(__name__)
創(chuàng)建的 Flask
對象
request
:指的是每次 HTTP
請求發(fā)生時,在 Flask
對象內(nèi)部創(chuàng)建的 Request
對象
在Flask
中處理請求時,應(yīng)用會生成“請求上下文”對象,保存當(dāng)前請求的相關(guān)數(shù)據(jù)信息,整個請求的處理過程,都會在這個上下文對象中進行,保證請求的處理過程獨立不受干擾。
請求上下文對象有:request
和session
,下面以request
為例具體講解。
在上篇文章Flask 請求鉤子的實現(xiàn) 我們說過,在 Flask
中有四種常用的請求鉤子,分別是: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'
通過請求我們發(fā)現(xiàn),在每個請求鉤子裝飾的處理函數(shù)中,我們都可以直接訪問 request
對象。而且,在其他普通函數(shù)內(nèi),無法訪問 request
對象,說明 request
對象并不是真正的全局變量,只是在請求上下文的生命周期內(nèi)可以訪問,離開了請求的生命周期,就無法訪問了。上面的請求鉤子裝飾的處理函數(shù),在請求處理的不同階段執(zhí)行,自然其內(nèi)部也可以訪問 request
對象。
上面說請求上下文是和請求相關(guān),請求上下文對象保存的是請求的相關(guān)數(shù)據(jù)信息,下面說一下應(yīng)用上下文,所謂應(yīng)用上下文,就是和當(dāng)前應(yīng)用相關(guān)的,應(yīng)用上下文對象是包含當(dāng)前應(yīng)用相關(guān)的信息。
應(yīng)用上下文對象有:current_app
和g
。
我們了解到,每個請求,都有一個 request
對象和視圖函數(shù)對應(yīng),可以理解為當(dāng)前請求(current request
), 而程序也會有多個實例的情況,為了能獲取對應(yīng)的程序?qū)嵗?,而不是固定的某一個程序?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
是一個本地代理,它的類型是werkzeug.local.LocalProxy
,它所代理的即是app
對象,也就是說current_app == LocalProxy(app)
。所以通過current_app.name
可以獲取當(dāng)前應(yīng)用的名稱,也就是tigeriaf_app
,使用current_app
是因為它也是一個ThreadLocal
變量,對它的改動不會影響到其他線程。我們可以通過current_app._get_current_object()
方法來獲取app對象。也可以在current_app
中存儲一些自定義的變量。
current_app
只在請求線程內(nèi)存在,它的生命周期就是在應(yīng)用上下文里。離開了應(yīng)用上下文,current_app
一樣無法使用。
g
對象是 Flask
程序全局的一個臨時變量,充當(dāng)中間媒介的作用。我們可以通過它傳遞一些數(shù)據(jù),g保存的是當(dāng)前請求的全局變量,每次請求都會重設(shè)這個值,我們通常會使用它結(jié)合請求鉤子來保存每個請求處理前所需要的全局變量,比如當(dāng)前登入的用戶對象,數(shù)據(jù)庫連接等。 比如,使用g對象保存請求的 token
,在視圖函數(shù)中就可以直接使用g.name
獲取對應(yīng)的值了。
from flask import g @app.before_request def get_token(): g.name = request.headers.get("token")
“Flask上下文舉例分析”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。