我正在尝试使用 Python 中的请求库将文件上传到本地主机上的 Fedora 公共存储库。我相当肯定我的主要问题是不理解open()/read()以及我需要做什么才能通过 http 请求发送数据。
def postBinary(fileName,dirPath,url):
path = dirPath+'/'+fileName
print('to ' + url + '\n' + path)
openBin = {'file':(fileName,open(path,'rb').read())}
headers = {'Slug': fileName} #not important
r = requests.put(url, files=openBin,headers=headers, auth=HTTPBasicAuth('username', 'pass'))
print(r.text)
print("and the url used:")
print(r.url)
Run Code Online (Sandbox Code Playgroud)
这将成功上传存储库中的文件,但之后它会稍大并损坏。例如,一个 6.6kb 的图像变成了 6.75kb 并且不再可以打开。
那么我应该如何使用 put in python 正确打开和上传文件?###额外的细节:###
当我替换files=openBin为data=openBin我的字典时,我将数据假定为字符串。我不知道这些信息是否有帮助。
"file=FILE_NAME.extension&file=TYPE89a%24%02Q%03%E7%FF%00E%5B%19%FC%....并且文件的大小增加到若干兆字节
我特别使用 put 因为 Fedora RESTful HTTP API 端点说要使用put.
以下命令确实有效:
curl -u username:password -H "Content-Type: …