【Python】使用 requests_toolbelt 发multipart/form-data 请求

本文介绍了如何处理multipart/form-data类型的POST请求,特别是在使用Python的requests库时。文章详细解释了multipart/form-data与application/json及application/x-www-form-urlencoded的区别,并提供了一个实际的编码案例。
1、multipart/form-data 请求

比较常见的 content-type 一般是以下2种:

application/json
application/x-www-form-urlencoded

使用requests发网络请求时,只要在data or json里带上对应的数据就能正常发请求了。

但是——
multipart/form-data 数据直接在放到data 里,一定报错。
这时,需要转码一下.

2、multipart/form-data 参数转码

比如请求参数是:

--e0ed233c-3202-47c6-9c96-f9181e308
Content-Disposition: form-data; name="id"
Content-Transfer-Encoding: binary
Content-Type: application/json; charset=UTF-8
Content-Length: 13

234545878
--e0ed233c-3202-47c6-9c96-f9181e308
Content-Disposition: form-data; name="type"
Content-Transfer-Encoding: binary
Content-Type: application/json; charset=UTF-8
Content-Length: 1

1
--e0ed233c-3202-47c6-9c96-f9181e308--

也就是说,有2个 key -> id 和 type

fields={
        "id": '234545878',
        "type": '1'
    }

直接这样发请求,会失败。⬆️

encode一下就能发请求了。⬇️

from requests_toolbelt.multipart.encoder import MultipartEncoder

multipart_data = MultipartEncoder(
    fields={
        "id": '1653302392217',
        "read_duration_list": read_duration_list,
        "now": now,
        "type": '1'
    }
)
header['Content-Type'] = multipart_data.content_type
header['accept'] = 'application/json'
3、一个实际案例
import requests
from requests_toolbelt.multipart.encoder import MultipartEncoder

upload_url = "https://api.code.com/upload"

now = str(get_msec())
read_duration_list= '[{"id":234545878,"type":2,"duration":11,"start_time":'+str(now)+',"trigger_page":"PersonalPage"}]'

multipart_data = MultipartEncoder(
    fields={
        "id": '1653302392217',
        "read_duration_list": read_duration_list,
        "now": now,
        "type": '1'
    }
)
header['Content-Type'] = multipart_data.content_type
header['accept'] = 'application/json'

upload = requests.post(upload_url, header=header, data=multipart_data)
print(f"upload:{upload}")
### 使用 Python 的 `requests` 库送包含 `multipart/form-data` 的 POST 请求 在 Web 开中,`multipart/form-data` 是一种常见的数据格式,用于通过 HTTP 协议上传文件或提交表单。Python 的 `requests` 库提供了强大的支持来处理这种格式的请求。 #### 1. 基本方法 `requests` 库的 `post` 方法可以直接通过 `files` 参数送 `multipart/form-data` 请求。当使用 `files` 参数时,`requests` 会自动设置正确的 `Content-Type` 并生成唯一的 `boundary`。 ```python import requests url = "https://example.com/upload" files = { 'currentRequestld': (None, '33799'), # 普通字段 'file': ('test.txt', open('test.txt', 'rb')) # 文件字段 } response = requests.post(url, files=files) print(response.text) ``` 在这个示例中,`currentRequestld` 是一个普通字段,而 `file` 是一个文件字段。`requests` 会自动处理边界值,并将数据编码为 `multipart/form-data` 格式[^1]。 #### 2. 自定义 `multipart/form-data` 数据 如果需要更精细地控制请求体,可以结合 `requests_toolbelt` 库中的 `MultipartEncoder` 类来自定义 `multipart/form-data` 内容。 ```python import requests from requests_toolbelt import MultipartEncoder # 定义字段 fields = { 'field0': 'value0', 'field1': 'value1', 'currentRequestld': '33799' } # 创建 MultipartEncoder m = MultipartEncoder(fields=fields) # 设置请求头 headers = { 'Content-Type': m.content_type } # 送 POST 请求 response = requests.post("https://example.com/api", data=m, headers=headers) print(response.status_code) print(response.text) ``` 在这个示例中,`MultipartEncoder` 负责生成 `multipart/form-data` 格式的请求体,并自动设置 `boundary`。这种方式适用于需要显式控制字段或调试请求内容的场景[^2]。 #### 3. 手动构造 `multipart/form-data` 请求 虽然 `requests` 会自动处理边界值,但在某些特殊情况下,可能需要手动构造请求体。例如,某些 API 要求特定的 `boundary` 或字段顺序。 ```python import requests # 手动定义 boundary 和请求体 boundary = "----WebKitFormBoundary7RgPwjW5Gf1JZ9SX" body = ( f"--{boundary}\r\n" 'Content-Disposition: form-data; name="currentRequestld"\r\n\r\n' '33799\r\n' f"--{boundary}--\r\n" ) headers = { 'Content-Type': f'multipart/form-data; boundary={boundary}' } response = requests.post("https://example.com/api", data=body, headers=headers) print(response.text) ``` 此方法适用于需要严格控制请求格式的场景,但通常推荐使用 `MultipartEncoder` 或 `files` 参数,以避免格式错误[^3]。 #### 4. 注意事项 - **字段类型**:在 `multipart/form-data` 请求中,字段可以是字符串、文件对象,甚至是二进制数据。 - **边界值(boundary)**:`multipart/form-data` 请求通过 `boundary` 分隔不同字段。如果使用 `MultipartEncoder` 或 `files` 参数,`requests` 会自动生成唯一的 `boundary`。 - **文件上传**:上传文件时需要提供文件名和文件对象,如 `('filename.txt', open('filename.txt', 'rb'))`。 - **内容类型**:确保请求头中包含正确的 `Content-Type: multipart/form-data`,并且包含 `boundary`。 --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值