我想向 HTTPS 站点发出发布请求,该站点应使用 .csv 文件进行响应。 我有这个 Python 代码:
url = 'https://www.site.com/servlet/datadownload'
values = {
'val1' : '123',
'val2' : 'abc',
'val3' : '1b3',
}
data = urllib.urlencode(values)
req = urllib2.Request(url,data)
response = urllib2.urlopen(req)
myfile = open('file.csv', 'wb')
shutil.copyfileobj(response.fp, myfile)
myfile.close()
但是出现错误:
BadStatusLine: '' (in httplib.py)
我已经尝试使用 Chrome 扩展的发布请求:高级 REST 客户端 (screenshot)效果很好。
可能是什么问题,我该如何解决? (是因为 HTTPS 吗?)
编辑,重构代码:
try:
#conn = httplib.HTTPSConnection(host="www.site.com", port=443)
=> 给出一个 BadStatusLine: ''
错误
conn = httplib.HTTPConnection("www.site.com");
params = urllib.urlencode({'val1':'123','val2':'abc','val3':'1b3'})
conn.request("POST", "/nps/servlet/exportdatadownload", params)
content = conn.getresponse()
print content.reason, content.status
print content.read()
conn.close()
except:
import sys
print sys.exc_info()[:2]
输出:
Found 302
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<HTML><HEAD>
<TITLE>302 Found</TITLE>
</HEAD><BODY>
<H1>Found</H1>
The document has moved <A HREF="https://www.site.com/nps/servlet/exportdatadownload">here</A>.<P>
<HR>
<ADDRESS>Oracle-Application-Server-10g/10.1.3.5.0 Oracle-HTTP-Server Server at mp-www1.mrco.be Port 7778</ADDRESS>
</BODY></HTML>
我做错了什么?
最佳答案
你有理由使用 urllib
吗? Requests更简单,几乎在所有方面都更好,并且抽象掉了一些使 urllib
难以使用的问题。
举个例子,我会把你的例子改成这样:
import requests
resp = requests.post(url, data=values, allow_redirects=True)
此时,来自服务器的响应在 resp.text
中可用,您可以用它做任何您想做的事。如果请求无法正确 POST(例如,因为您需要自定义 SSL 证书),它应该给您一个很好的错误消息,告诉您原因。
即使您不能在生产环境中执行此操作,也可以在本地 shell 中执行此操作以查看从 requests
中获得的错误消息,并使用它来调试 urllib
.
关于python - HTTPS POST 请求 Python,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14385173/