我希望向一个HTTPS网站发起POST请求,该网站应该用.csv文件进行响应。
我有以下Python代码:
但是我收到了错误提示:
我已经尝试使用Chrome扩展程序:高级REST客户端(截图)进行POST请求,它可以正常工作。
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客户端(截图)进行POST请求,它可以正常工作。
可能的问题是什么,如何解决?(是因为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>
我做错了什么?
https_handler = urllib2.HTTPSHandler(1)
opener = urllib2.build_opener(https_handler)
response = opener.open(req)
代替response = urllib2.urlopen(req)
,会得到什么结果?您仍然应该会收到错误信息,但这将打开https响应的调试功能,这意味着您的响应将被打印出来,您可以利用它来帮助跟踪问题所在。如果由于某种奇怪的原因而使用了另一个处理程序,请尝试使用urllib2.HTTPHandler(1)
或其他相关处理程序进行相同的操作。 - Silas Ray