请参阅下面的代码。基本上它是一个脚本,它以主机名作为参数查询API服务,然后返回与该服务器关联的一些元数据。现在,从已经安装到Windows机器的Python 2.7
编译器执行时,它的工作效果非常好,也可以使用bash CLI中的CURL
工作(意味着URL肯定在工作),但是这个脚本将在具有嵌入式JVM包装器的HP应用程序上运行,这意味着它将使用Jython
而不是CPython
,就像我的本地机器一样 - 至少我认为是问题是。这就是导致第一个问题的原因 - SSL握手将失败,因为虽然CPython忽略了证书,但Jython没有。由于此内部API的证书是自签名的,因此我得到了:
jvm 1 | sslerror(-1, 'SSL handshake exception: Differences between the SSL socket behaviour of cpython vs. jython are explained on the wiki: http://wiki.python.org/jython/NewSocketModule#SSL_Support')
尝试使用HTTP时,我收到错误代码400:
400: ('Bad Request', 'Bad request syntax or unsupported method')
我认为值得注意的是,这不是一个网络问题。我可以使用HTTP从浏览器中获取数据。
理想情况下,我会对不安全的HTTP感到满意,因为它无论如何都是内部服务。此外,信任证书将成为问题,因为我的脚本将在45-50台不同的机器上运行,增加了太多的开销。
此外,使用urllib2之外的其他东西(例如Python请求模块)将是一个问题,因为任何非ootb都必须分发给所有机器,再次增加了不可接受的开销。
我发现了这个:trusting all certificates in Jython,但坦率地说,我不太了解。
我想我的问题是:为什么HTTP失败?
编辑:将一些证书导入JVM的密钥库,现在我似乎正在通过SSL层,但它仍然以代码400响应。
import urllib2
import base64
baseUrl = 'https://my-api-example.com/'
hostname = 'server1.example.com'
username = "vinnie"
password = 'pooh'
request = urllib2.Request(baseUrl + hostname)
base64string = base64.encodestring('%s:%s' % (username, password))
request.add_header("Authorization", "Basic %s" % base64string)
try:
data = urllib2.urlopen(request)
print data.read()
except urllib2.HTTPError, e:
print e.code
except urllib2.URLError, e:
print e.reason
except:
print 'Undefined error'
答案 0 :(得分:0)
我设法通过打印出“请求”实例的属性来自行解决。这样做表明base64.encode显然返回带有尾随换行符号的字符串,这导致服务器响应400.我猜使用编码会绕过问题,虽然我无法理解为什么base64.encode给出了值首先是一个尾随的换行符。
案件结束......