每一個框架中都有處理請求的機制(request),可是每一個框架的處理方式和機制是不一樣的html
爲了瞭解Flask的request中都有什麼東西,首先咱們要寫一個先後端的交互前端
基於HTML + Flask 寫一段先後端的交互json
先寫一段兒HTML form表單中提交方式是post action地址是 /reqflask
寫好一個標準 form 表單,一點提交,搜就向後端提交一個POST請求過去了後端
後端的接收方式就 666 了瀏覽器
首先要從 flask 包中導入 request 模塊 , 至於爲何要導入 request 呢? 這裏不作解釋,暫時你就知道 request 若是要用,須要導入cookie
解釋一個 @app.route("/req",methods=["POST"]) :app
methods=["POST"] 表明這個url地址只容許 POST 請求,是個列表也就是意味着能夠容許多重請求方式,例如GET之類的框架
Flask 的 request 中給咱們提供了一個 method 屬性裏面保存的就是前端的請求的方式post
print(request.method) # POST 看來可使用這種方式來驗證請求方式了
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) # 若是你以爲用字典更爽的話,也能夠轉成字典操做(這裏有坑)
request.args 中保存的是url中傳遞的參數
先把後端請求代碼改動一下:
而後使用URL地址直接傳遞參數
而後會在控制檯中看到 ImmutableMultiDict([('id', '1'), ('age', '20')])
哎呀我去,這不是和剛纔同樣嗎? 是的!
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表單中的參數
改動一下前端代碼:
這是讓咱們在使用form表單提交的同時使用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'}
前提是你要開啓瀏覽器的 cookies
request.cookies 是將cookies中信息讀取出來
用來獲取本次請求的請求頭
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 """
你必定要知道 request 是基於 mimetype 進行處理的
mimetype的類型 以及 字符串兒 : http://www.w3school.com.cn/media/media_mimeref.asp
若是不屬於上述類型的描述,request就會將沒法處理的參數轉爲Json存入到 data 中
其實咱們能夠將 request.data , json.loads 一樣能夠拿到裏面的參數
若是遇到文件上傳的話,request.files 裏面存的是你上傳的文件,可是 Flask 在這個文件的操做中加了必定的封裝,讓操做變得極爲簡單
首先改下前端代碼:
後端這樣寫
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" 的文件了,操做仍是很簡單的
# 獲取當前的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/
若是在請求中寫入了 "application/json" 使用 request.json 則返回json解析數據, 不然返回 None