3

我已成功使用requests模块上传二进制文件(jpg),内容如下:

upload_url = 'http:10.1.1.1:8080/api/media/photo'
headers = {'Authorization': token_string, 'Content-Type': 'image/jpg'}
data = open('photo.JPG', 'rb')
params = {'name': 'photo.JPG'}
r = requests.post(upload_url, params=params, data=data, headers=headers)

现在尝试使用aiohttp客户端执行此操作。这是我到目前为止所拥有的:

def upload_photos(token):
    upload_url = '10.0.1.1:8080/api/media/photo'
    headers = {'Authorization': token, 'Content-Type': 'image/jpg'}
    data = {'file': open('photo.JPG', 'rb')}
    params = {'name': 'photo.JPG'}
    r = yield from aiohttp.request('post', upload_url, params=params, data=data, headers=headers)

if __name__ == '__main__':     
    asyncio.get_event_loop().run_until_complete(upload_photos(token))

但是我得到了 400 的回报,带有{"detail": "Specified value is invalid: Invalid Content-Length specified"}.
好像它没有正确发送photo.jpg。aiohttp 文档提到了多部分编码文件和流式传输,但这不是我想要的。

如何在请求中形成类似的带有二进制文件的 POST,但使用 aiohttp?

4

1 回答 1

0

感谢您的错误报告。作为解决方法,我想使用分块传输编码:

headers['Transfer-Encoding'] = 'chunked'
r = yield from aiohttp.request('post', upload_url, params=params, data=data, headers=headers, chunked=1024) 

配方应该可以工作,至少我们的测试套件中有非常相似的代码:https ://github.com/KeepSafe/aiohttp/blob/master/tests/test_client_functional.py#L322

我将尝试在下一个 aiohttp 版本中为您的上传方式修复Content-Length计算。

于 2015-04-02T15:32:47.167 回答