本節(jié)講解了 flask 的請求,如果想在沒有請求的情況下獲取上下文,可以使用test_request_context()或者request_context(),從request對象的form中可以獲取表單的數(shù)據(jù),args中可以獲取 URL 中的參數(shù),files可以獲取上傳的文件,cookies可以操作cookie。
首先你需要從 flask 模塊中導(dǎo)入request:
from flask import request
當(dāng)前請求的方法可以用method屬性來訪問。你可以用form屬性來訪問表單數(shù)據(jù) (數(shù)據(jù)在 POST 或者PUT中傳輸)。這里是上面提及到的兩種屬性的完整的例子,請重新修改hello.py文件為:
@app.route('/login', methods=['POST', 'GET']) def login(): error = None if request.method == 'POST': if valid_login(request.form['username'], request.form['password']): return log_the_user_in(request.form['username']) else: error = 'Invalid username/password' # 當(dāng)請求形式為“GET”或者認(rèn)證失敗則執(zhí)行以下代碼 return render_template('login.html', error=error)
如果在form屬性中不存在上述鍵值會(huì)發(fā)生些什么?在這種情況下會(huì)觸發(fā)一個(gè)特別的KeyError。你可以像捕獲標(biāo)準(zhǔn)的KeyError一樣來捕獲它,如果你不這樣去做,會(huì)顯示一個(gè)HTTP 400 Bad Request錯(cuò)誤頁面。所以很多情況下你不需要處理這個(gè)問題。
你可以用args屬性來接收在URL ( ?key=value )中提交的參數(shù):
searchword = request.args.get('key', '')
我們推薦使用get來訪問 URL 參數(shù)或捕獲KeyError,因?yàn)橛脩艨赡軙?huì)修改 URL, 向他們顯示一個(gè)400 bad request頁面不是用戶友好的。
你能夠很容易地用 Flask 處理文件上傳。只要確保在你的 HTML 表單中不要忘記設(shè)置屬性enctype="multipart/form-data",否則瀏覽器將不會(huì)傳送文件。
上傳的文件是存儲(chǔ)在內(nèi)存或者文件系統(tǒng)上一個(gè)臨時(shí)位置。你可以通過請求對象中files屬性訪問這些文件。每個(gè)上傳的文件都會(huì)存儲(chǔ)在這個(gè)屬性字典里。它表現(xiàn)得像一個(gè)標(biāo)準(zhǔn)的 Python file對象,但是它同樣具有save()方法,該方法允許你存儲(chǔ)文件在服務(wù)器的文件系統(tǒng)上。
下面是一個(gè)簡單的例子用來演示提交文件到服務(wù)器上:
from flask import request @app.route('/upload', methods=['GET', 'POST']) def upload_file(): if request.method == 'POST': f = request.files['the_file'] f.save('/var/www/uploads/uploaded_file.txt') ...
如果你想要知道在上傳到你的應(yīng)用之前在客戶端的文件名稱,你可以訪問filename屬性。但請記住永遠(yuǎn)不要信任這個(gè)值,因?yàn)檫@個(gè)值可以偽造。如果你想要使用客戶端的文件名來在服務(wù)器上存儲(chǔ)文件,把它傳遞到Werkzeug提供給你的secure_filename()函數(shù):
from flask import request from werkzeug import secure_filename @app.route('/upload', methods=['GET', 'POST']) def upload_file(): if request.method == 'POST': f = request.files['the_file'] f.save('/var/www/uploads/' + secure_filename(f.filename)) ...
3.1.4 Cookies
你可以用cookies屬性來訪問cookies。你能夠用響應(yīng)對象的set_cookie來設(shè)置cookies。請求對象中的cookies屬性是一個(gè)客戶端發(fā)送所有的cookies的字典。
如果你要使用會(huì)話(sessions),請不要直接使用cookies,相反,請用 Flask 中的會(huì)話,F(xiàn)lask 已經(jīng)在cookies上增加了一些安全細(xì)節(jié);關(guān)于更多seesions和cookies的區(qū)別與聯(lián)系,請參見施楊出品的博客。
讀取 cookies:
from flask import request @app.route('/') def index(): username = request.cookies.get('username') # 注意這里引用cookies字典的鍵值對是使用cookies.get(key) # 而不是cookies[key],這是防止該字典不存在時(shí)報(bào)錯(cuò)"keyerror"
存儲(chǔ) cookies:
from flask import make_response @app.route('/') def index(): resp = make_response(render_template(...)) resp.set_cookie('username', 'the username') return resp
注意cookies是在響應(yīng)對象中被設(shè)置。由于通常只是從視圖函數(shù)返回字符串, Flask 會(huì)將其轉(zhuǎn)換為響應(yīng)對象。如果你要顯式地這么做,你可以使用 make_response()函數(shù)接著修改它。
有時(shí)候你可能要在響應(yīng)對象不存在的地方設(shè)置cookie。利用 延遲請求回調(diào)模式使得這種情況成為可能。
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
