我想向一个应该用.csv文件响应的HTTPS站点发出post请求。 我有这个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扩展的post请求:advancedsrestclient(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>
我做错什么了?
BadStatusLine: '' (in httplib.py)
泄露了这里可能还有其他事情发生。当服务器根本不发送回复,而只是关闭连接时,可能会发生这种情况。正如您所提到的,您正在使用SSL连接,这可能对调试特别有兴趣(如果需要,可以使用
curl -v URL
)。 如果您发现curl -2 URL
(强制使用SSLv2)似乎起作用,而curl -3 URL
(SSLv3)则不起作用,那么您可能需要查看python bug tracker上的问题#13636和#11220。取决于Python版本&;一个可能配置错误的web服务器,这可能会导致一个问题:SSL默认值在v2.7.3中已更改。你有理由使用
urllib
?Requests更简单,几乎在所有方面都更好,并且抽象出一些使urllib
难以处理的关键。作为一个例子,我会把你的例子改写为:
此时,服务器的响应在
resp.text
中可用,您可以使用它做您想做的事情。如果请求无法正确发布(例如,因为您需要自定义SSL证书),它应该会给出一个很好的错误消息,告诉您原因。即使在生产环境中无法执行此操作,也可以在本地shell中执行此操作,以查看从
requests
获得的错误消息,并使用该消息调试urllib
。相关问题 更多 >
编程相关推荐