日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

Python?Flask的request對象使用詳解_python

作者:qq_42307546 ? 更新時間: 2023-04-26 編程語言

必知的Flask的request Flask Request對象

來?客戶端??的數據作為全局請求對象發送到服務器。為了處理請求數據,應該從Flask模塊導 ?。

Request對象的重要屬性如下所列:

form - 它是?個字典對象,包含表單參數及其值的鍵和值對。

args - 解析查詢字符串的內容,它是問號(?)之后的URL的?部分。

Cookies - 保存Cookie名稱和值的字典對象。

files - 與上傳?件有關的數據。

method - 當前請求?法

使?request也?較簡單,就是直接從從 flask 模塊導?請求對象:

from flask import request

"""args - 解析查詢字符串的內容,它是問號(?)之后的URL的?部分。"""
@app.route('/login', methods=['POST', 'GET'])
 def login():
      if request.method == 'POST':
      		user = request.form['nm']
      		return redirect(url_for('do_welocome',name = user))
       else:
       user = request.args.get("nm")
       return redirect(url_for('do_welocome',name = user))

必知的Flask的Cookies獲取數據 Cookie以?本?件的形式存儲在客戶端的計算機上。

其?的是記住和跟蹤與客戶使?相關的數據,以獲得更好的訪問者體驗和?站統計信息。

Flask的Request對象包含Cookie的屬性。

它是所有cookie變量及其對應值的字典對象

除此之外,cookie還存儲其?站的到期時間,路徑和域名。

在Flask中,對cookie的處理步驟為:

1 設置cookie:

設置cookie,默認有效期是臨時cookie,瀏覽器關閉就失效

可以通過 max_age 設置有效期, 單位是秒

2 獲取cookie

獲取cookie,通過request.cookies的?式, 返回的是?個字典,可以獲取字典?的相應的值

3 刪除cookie

這?的刪除只是讓cookie過期,并不是直接刪除cookie

刪除cookie,通過delete_cookie()的?式, ??是cookie的名字

from flask import  Flask,request,render_template,make_response
app = Flask(__name__)
@app.route('/setcookies')
def set_cookie():
    rep = make_response('設置cookies成功cookie:zhen guo:33')
    rep.set_cookie("zhen guo", '33',max_age = 3600)
    return rep
@app.route('/getcookie')
def get_cookie():
    cookie_value = request.cookies.get('zhen guo')
    return cookie_value
@app.route('/del_cookie')
def del_cookie():
    rep = make_response('刪除cookie成功')
    rep.delete_cookie('zhen guo')
    return rep
if __name__ == "__main__":
    app.debug = True
    app.run('127.0.0.1',5000)

Flask ?件上傳 在 Flask 中處理?件上傳?常簡單。

只需要?個 HTML 表單,其enctype屬性設置為’multipart/form-data’,將?件發布到 URL。

URL 處理程序從request.files[]對象中提取?件,并將其保存到所需的位置

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<form action="http://127.0.0.1:5000/uploader" method="POST" enctype="multipart/form-data">
<p><input type="file" name="file1" accept=".jpg,.png,.xlsx,.xls"/></p>
<p><input type="submit"/></p> </form>
</body>
</html> 

每個上傳的?件?先會保存在服務器上的臨時位置

然后將其實際保存到它的Y終位置。

?標?件的名稱可以是硬編碼的

也可以從 request.files[file]對象的filename屬性中獲取。

但是,建議使?secure_filename()函數獲取它的安全版本

Flask對象的配置設置中定義默認上傳?件夾的路徑和上傳?件的Y?值

app.config[‘UPLOAD_FOLDER?] 定義上傳?件夾的路徑

app.config[‘MAX_CONTENT_LENGTH?] 指定要上傳的?件的Y?值(以字節為單位

from flask import  Flask,request,render_template,make_response
from werkzeug.utils import secure_filename
import os
app = Flask(__name__)
app.config['UPLOAD_FOLDER'] = r'D:\pythonProject1\static'
@app.route('/')
def index():
    return render_template('upload.html')
@app.route('/uploader',methods=['POST','GET'])
def upload():
    if request.method == "POST":
        f = request.files['file1']
        filename = secure_filename(f.filename)
        f.save(os.path.join(app.config['UPLOAD_FOLDER'],filename))
        return f'文件{filename}上傳成功'
if __name__ == "__main__":
    app.debug = True
    app.run('127.0.0.1', 5000)

原文鏈接:https://blog.csdn.net/qq_42307546/article/details/128960275

欄目分類
最近更新