HTTPS使用Jython

时间:2015-11-25 08:54:26

标签: python ssl urllib2 jython

请参阅下面的代码。基本上它是一个脚本,它以主机名作为参数查询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'

1 个答案:

答案 0 :(得分:0)

我设法通过打印出“请求”实例的属性来自行解决。这样做表明base64.encode显然返回带有尾随换行符号的字符串,这导致服务器响应400.我猜使用编码会绕过问题,虽然我无法理解为什么base64.encode给出了值首先是一个尾随的换行符。

案件结束......