python - 在 Python2.7.9 的形式源安装后我得到 ssl.SSLError : [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl. c:581)

标签 python python-2.7 ssl

我使用的是 CentOS 6.6。因此我没有我需要的最新(2.7 系列)Python 包。我已经从源代码安装了 Python 2.7.9 到/usr/local/lib/python2.7 :

ll /usr/local/lib/python2.7/
total 52K
drwxr-xr-x. 2 root root 4.0K Jan 13 14:59 bin
drwxr-xr-x. 3 root root 4.0K Jan  7 15:15 include
drwxr-xr-x. 4 root root 4.0K Jan  7 15:15 lib
-rw-r--r--. 1 root root  12K Jan 14 11:46 LICENSE.txt
-rw-r--r--. 1 root root  117 Jan 14 11:46 MANIFEST.in
-rw-r--r--. 1 root root  238 Jan 14 11:46 NOTICE.txt
-rw-r--r--. 1 root root   88 Jan 14 11:46 setup.cfg
-rw-r--r--. 1 root root 2.6K Jan 14 11:46 setup.py
drwxr-xr-x. 3 root root 4.0K Jan  7 15:15 share
drwxr-xr-x. 6 root root 4.0K Jan  7 15:03 site-packages
-rw-r--r--. 1 root root  113 Jan 14 11:46 tox.ini

现在我有一个使用 pysphere 的脚本它曾经工作正常(并且在其他 2.6 和 2.7 机器上工作正常)但是当我用我当前的设置运行它时我得到这个:

$ python main.py
Connecting to vSphere...
Traceback (most recent call last):
  File "main.py", line 51, in <module>
    server.connect(VSPHERE_IP, VSPHERE_USER, VSPHERE_PASS)
  File "/usr/local/lib/python2.7/lib/python2.7/site-packages/pysphere/vi_server.py", line 101, in connect
    request)._returnval
  File "/usr/local/lib/python2.7/lib/python2.7/site-packages/pysphere/resources/VimService_services.py", line 2170, in RetrieveServiceContent
    self.binding.Send(None, None, request, soapaction="urn:vim25/5.0", **kw)
  File "/usr/local/lib/python2.7/lib/python2.7/site-packages/pysphere/ZSI/client.py", line 295, in Send
    self.local.h.connect()
  File "/usr/local/lib/python2.7/lib/python2.7/httplib.py", line 1212, in connect
    server_hostname=server_hostname)
  File "/usr/local/lib/python2.7/lib/python2.7/ssl.py", line 350, in wrap_socket
    _context=self)
  File "/usr/local/lib/python2.7/lib/python2.7/ssl.py", line 566, in __init__
    self.do_handshake()
  File "/usr/local/lib/python2.7/lib/python2.7/ssl.py", line 788, in do_handshake
    self._sslobj.do_handshake()
ssl.SSLError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:581)

$ pip -V
pip 6.0.6 from /usr/local/lib/python2.7/lib/python2.7/site-packages (python 2.7)
$ pip freeze
Django==1.7.2
docutils==0.12
ecdsa==0.11
paramiko==1.15.2
pep8==1.5.7
pycrypto==2.6.1
Pygments==2.0.1
pysphere==0.1.7
pyvmomi==5.5.0.2014.1.1
requests==2.5.1
six==1.9.0
virtualenv==12.0.5

这里有什么问题?

最佳答案

我迟到了几年,但我自己遇到了这个问题,并找到了解决方案。如果将来有人偶然发现此线程,我将发表评论。

发生这种情况的原因(这是 Patryk 的问题)是 Python 的 httplib.HTTPSConnection以前默认不验证 SSL 证书。从 Python 2.7.9 开始,SSL validation is required .如果您的 ESX 服务器的 SSL 证书有问题,连接将失败。

不幸的是the pysphere library is no longer maintained .

假设您正尝试在私有(private)和安全的环境中使用 pysphere 库,您可以将以下补丁应用于 pysphere/ZSI/client.py 文件:

294c294,295
<         self.local.h = transport(netloc, None, **self.transdict)
---
>         import ssl
>         self.local.h = transport(netloc, None, context=ssl._create_unverified_context(), **self.transdict)

说明:pysphere 库使用httplib.HTTPSConnection 建立与ESX 服务器的连接。如果它遇到 SSL 证书问题,它将失败并出现上述异常。要恢复 Python 2.7.9 之前的行为,您需要告诉 httplib.HTTPSConnection 不验证 SSL 证书。

关于python - 在 Python2.7.9 的形式源安装后我得到 ssl.SSLError : [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl. c:581),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27941447/

相关文章:

python - Django dateutil ISO 8601 没有 'read' 属性错误

python - Google App Engine NDB 排序丢失实体

python - Python套接字errno 32损坏的管道

python - 如何使用函数打破循环

javascript - 无法在浏览器中运行 python Web 应用程序

python - BeautifulSoup getText 从 <p> 之间,不拾取后续段落

python - Python 中 '\0\0' 的含义?

c# - HttpWebrequest 失败,yande.re(以及 IE 和 curl)["The request was aborted: Could not create SSL/TLS secure channel."]

java - SSLEngine:在成功握手后展开时无效的 TLS 填充数据

ssl - 如何在 Go 中建立到 memsql 的基于 ssl 的 tcp 连接