post請求四種傳送正文方式首先需要先了解一下常見的四種編碼方式:
HTTP 協(xié)議規(guī)定 POST 提交的數(shù)據(jù)必須放在消息主體(entity-body)中斗幼,但協(xié)議并沒有規(guī)定數(shù)據(jù)必須使用什么編碼方式。常見的四種編碼方式如下:
1淤齐、application/x-www-form-urlencoded
這應(yīng)該是最常見的 POST 提交數(shù)據(jù)的方式了蒲列。瀏覽器的原生 form 表單蒜撮,如果不設(shè)置 enctype 屬性组底,那么最終就會以 application/x-www-form-urlencoded 方式提交數(shù)據(jù)糜工。請求類似于下面這樣(無關(guān)的請求頭在本文中都省略掉了):
POST http://www.example.com HTTP/1.1 Content-Type:
application/x-www-form-urlencoded;charset=utf-8
title=test&sub%5B%5D=1&sub%5B%5D=2&sub%5B%5D=3
import requests
import json
from urllib import parse
# 定義請求header
HEADERS = {'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8', 'Key': '332213fa4a9d4288b5668ddd9'}
# 定義請求地址
url = "https://api.newrank.cn/api/sync/weibo/trend"
# 通過字典方式定義請求body
FormData = {"from": '2018-07-18 16:00:00', "to": '2018-07-18 18:00:00', "page": 1, "size": 1}
# 字典轉(zhuǎn)換k1=v1 & k2=v2 模式
data = parse.urlencode(FormData)
# 請求方式
content = requests.post(url=url, headers=HEADERS, data=data).text
content = json.loads(content)
print(content)
2、multipart/form-data
除了傳統(tǒng)的application/x-www-form-urlencoded表單鬼悠,我們另一個經(jīng)常用到的是上傳文件用的表單,這種表單的類型為multipart/form-data亏娜。
這又是一個常見的 POST 數(shù)據(jù)提交的方式焕窝。我們使用表單上傳文件時,必須讓 form 的 enctyped 等于這個值维贺,下面是示例
POST http://www.example.com HTTP/1.1
Content-Type:multipart/form-data; boundary=----WebKitFormBoundaryrGKCBY7qhFd3TrwA
------WebKitFormBoundaryrGKCBY7qhFd3TrwA
Content-Disposition: form-data; name="text"
title
------WebKitFormBoundaryrGKCBY7qhFd3TrwA
Content-Disposition: form-data; name="file"; filename="chrome.png"
Content-Type: image/png
PNG ... content of chrome.png ...
------WebKitFormBoundaryrGKCBY7qhFd3TrwA--
from requests_toolbelt import MultipartEncoder
multipart_data = MultipartEncoder(
fields={
"appid": "yocial_export",
"functionId": "v1_basic_external_load",
"body": '{"inviter": "hello"}',
"t": "1589955388453",
"sign":"2f1e3c25c463dd506760395c90f1407725cb4388d825074e0597a38179f8a614"
}
)
print(multipart_data.content_type)
url = " [http://api.m.jd.com/v1/basic/external/load](http://api.m.jd.com/v1/basic/external/load)"
response = requests.post(url=url,data=multipart_data,
headers={'Content-Type': multipart_data.content_type})
print(response.content)
3它掂、application/json
application/json 這個 Content-Type 作為響應(yīng)頭大家肯定不陌生。實際上溯泣,現(xiàn)在越來越多的人把它作為請求頭虐秋,用來告訴服務(wù)端消息主體是序列化后的 JSON 字符串。由于 JSON 規(guī)范的流行垃沦,除了低版本 IE 之外的各大瀏覽器都原生支持 JSON.stringify客给,服務(wù)端語言也都有處理 JSON 的函數(shù),使用 JSON 不會遇上什么麻煩肢簿。
4靶剑、text/xml
它是一種使用 HTTP 作為傳輸協(xié)議,XML 作為編碼方式的遠(yuǎn)程調(diào)用規(guī)范池充。
post請求四種傳送正文方式:
(1)請求正文是application/x-www-form-urlencoded
requests.post(url='',
data={'key1':'value1','key2':'value2'},
headers={'Content-Type':'application/x-www-form-urlencoded'})
(2)請求正文是multipart/form-data
requests.post(url='',
data={'key1':'value1','key2':'value2'},
headers={'Content-Type':'multipart/form-data'})
pip install requests-toolbelt
from requests_toolbelt import MultipartEncoder
import requests
m = MultipartEncoder(
fields={
'field0': 'value',
'field1': 'value',
'field2': ('filename', open('file.py', 'rb'), 'text/plain'),
'filed3': ("aab.jpg", open("aab.jpg", 'rb'), "image/jpeg")
})
r = requests.post('http://httpbin.org/post', data=m,
headers={'Content-Type': m.content_type})
# multipart/form-data; boundary=e2cbedfe3ba94a4d81052fa81deb41a3
(3)請求正文是raw
?傳入xml格式文本
requests.post(url='',
data='<?xml ?>',
headers={'Content-Type':'text/xml'})
?傳入json格式文本
requests.post(url='',
data=json.dumps({'key1':'value1','key2':'value2'}),
headers={'Content-Type':'application/json'})
或者
requests.post(url='',
json={{'key1':'value1','key2':'value2'}},
headers={'Content-Type':'application/json'})
(4)請求正文是binary
requests.post(url='',
files={'file':open('test.xls','rb')},
headers={'Content-Type':'binary'})