flask 中的request


每個框架中都有處理請求的機制(request),但是每個框架的處理方式和機制是不同的,為了了解flask的request中都有什么東西,首先我們要寫一個前后端的交互

基於HTML+Flask 寫一段前后端交互

前端HTML

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>login</title>
</head>
<body>
<form action="" method="post">
    <input type="text" name="username">
    <input type="password" name="password">
    <input type="submit">
</form>
</body>
</html>

后端代碼,首先需要從flask包中導入request模塊,

from flask import Flask, request, render_template


app = Flask(__name__)


@app.route('/')
def hello_world():
    return 'Hello World!'


@app.route('/login', methods=["GET", "POST"])
def login():
    print(request.form)
    print(request.data)
    print(request.method)
    print(request.values)
    print(request.headers)
    print(request.args)
    print(request.json)
    return render_template("login.html")


if __name__ == '__main__':
    app.run()

然后運行這個項目,訪問 http://127.0.0.1:5000/login 會得到如下頁面

解釋一個 @app.route("/req",methods=["POST"]) :

methods=["POST"]  代表這個url地址只允許 POST 請求,是個列表也就是意味着可以允許多重請求方式,例如GET之類的

1.request.method之肯定知道前端用什么方式提交的

flask的request中給我們提供了一個method屬性里面保存的就是前端的請求方式

print(request.method) # POST 看來可以使用這種方式來驗證請求方式了

 

2.request.form

form表單中傳遞過來的值,使用request.form中拿到

    print(request.form)  # ImmutableMultiDict([('user', 'Oldboy'), ('pwd', 'DragonFire')])
    # ImmutableMultiDict 它看起來像是的Dict 就用Dict的方法取值試一下吧
    print(request.form["user"])  # Oldboy
    print(request.form.get("pwd"))  # DragonFire
    # 看來全部才對了, ImmutableMultiDict 似乎就是個字典,再來玩一玩它
    print(list(request.form.keys()))  # ['user', 'pwd'] 看來是又才對了
    #如果以上所有的方法你都覺得用的不爽的話
    req_dict = dict(request.form)
    print(req_dict)  # 如果你覺得用字典更爽的話,也可以轉成字典操作(這里有坑)

 

3.request.args 

request.args中保存的是url中傳遞的參數

先把后端請求代碼改動一下:

from flask import request
@app.route("/req", methods=["POST", "GET"])
def req():
    print(request.args)
    return "ok"

 

然后使用URL地址直接傳遞參數

控制台會輸出以下結果:

ImmutableMultiDict([('name', '小白'), ('age', '18')])
    print(request.args)  # ImmutableMultiDict([('id', '1'), ('age', '20')])
    print(request.args["id"])  # 1
    print(request.args.get("age"))  # 20
    print(list(request.args.keys()))  # ['id', 'age']
    print(list(request.args.values()))  # ['1', '20']
    req_dict = dict(request.args)  # {'id': ['1'], 'age': ['20']}
    print(req_dict)

 

request.args與request.form的區別就是:

request.args是獲取url中的參數

request.form是獲取form表單中的參數

4.request.values

獲取formdata數據和URL中的數據

這時我們提交表單數據同時提交url參數

print(request.values)  # CombinedMultiDict([ImmutableMultiDict([('id', '1'), ('age', '20')]), ImmutableMultiDict([('user', 'Oldboy'), ('pwd', 'DragonFire')])])
print(request.values.get("id"))  # 1
print(request.values["user"])  # Oldboy
# 這回喜歡直接操作字典的小伙伴們有驚喜了! to_dict() 方法可以直接將我們的參數全部轉為字典形式
print(request.values.to_dict()) # {'user': 'Oldboy', 'pwd': 'DragonFire', 'id': '1', 'age': '20'}

 

注意啦!注意啦!

# 注意這里的坑來啦! 坑來啦!
# 如果url和form中的Key重名的話,form中的同名的key中value會被url中的value覆蓋
# http://127.0.0.1:5000/req?id=1&user=20
print(request.values.to_dict())  # {'user': 20 'pwd': 'DragonFire', 'id': '1'}

5.request.cookies

存在瀏覽器端的字符串一起帶過來

前提是要開啟瀏覽器中的cookies

request.cookies 是將cookies中信息讀出來

 

6.request.headres 

用來獲取本次請求的請求頭

    print(type(request.headers))
    """
    Host: 127.0.0.1:5000
    User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:60.0) Gecko/20100101 Firefox/60.0
    Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
    Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2
    Accept-Encoding: gzip, deflate
    Referer: http://127.0.0.1:5000/home
    Content-Type: application/x-www-form-urlencoded
    Content-Length: 26
    Cookie: csrftoken=vDIozqveCEfArdYXlM6goHVlSQEn7h4bDygNphL2Feas60DiM2di0jlqKfxo7xhA
    Connection: keep-alive
    Upgrade-Insecure-Requests: 1
    Cache-Control: max-age=0
    """

7.request.data 之 如果處理不了的就變成字符串兒存在data里面

你一定要知道 request 是基於 mimetype 進行處理的

mimetype的類型 以及 字符串兒 : http://www.w3school.com.cn/media/media_mimeref.asp

如果不屬於上述類型的描述,request就會將無法處理的參數轉為Json存入到 data 中

其實我們可以將 request.data , json.loads 同樣可以拿到里面的參數

 8.request.files

如果遇到文件上傳的話,request.files里面存在的是你上傳的文件,但是flask在這個文件的操作中加了一定的封裝,讓操作變得極為簡單

<form action="/req" method="post" enctype="multipart/form-data">
    <input type="file" name="file">
    <input type="submit">
</form>

 

 

 

后端這樣寫

    print(request.files)  # ImmutableMultiDict([('file', <FileStorage: 'DragonFire.txt' ('text/plain')>)])
    print(request.files["file"])  # <FileStorage: 'DragonFire.txt' ('text/plain')>
    my_file = request.files["file"]
    my_file.save("OldBoyEDU.txt")  # 保存文件,里面可以寫完整路徑+文件名

 

這樣我們就成功的保存了一個名叫 "OldBoyEDU.txt" 的文件了,操作還是很簡單的

9.request.獲取各種路徑

    # 獲取當前的url路徑
    print(request.path)# /req
    # 當前url路徑的上一級路徑
    print(request.script_root) #
    # 當前url的全部路徑
    print(request.url) # http://127.0.0.1:5000/req
    # 當前url的路徑的上一級全部路徑
    print(request.url_root ) # http://127.0.0.1:5000/

 

10. request.json 之 前提你得告訴是json

如果在請求中寫入了 "application/json" 使用 request.json 則返回json解析數據, 否則返回 None

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM