簡體   English   中英

請求(僅)* .google.com時,SSL上的SSL3_GET_SERVER_CERTIFICATE證書驗證失敗

[英]SSL3_GET_SERVER_CERTIFICATE certificate verify failed on Python when requesting (only) *.google.com

我遇到了一個非常奇怪的錯誤,它與SSL和python有關google.com(或者更常見的是我認為有多個證書鏈的域名)。 每當我嘗試向https://*.google.com/whatever請求時,我都會收到以下錯誤消息:

SSLError: ("bad handshake: Error([('SSL routines', 'SSL3_GET_SERVER_CERTIFICATE', 'certificate verify failed')],)",) while doing GET request to URL: https://google.com/

到目前為止我做了什么

我已經經歷了很多嘗試讓這個工作起來的箍,並且現在因為我不知道該怎么做而訴諸Stack Overflow。 這是我嘗試過的:

  1. 注意到date返回的日期比實時晚了2分鍾(可能使我的證書無效)。 假設它會驗證證書,我修復了這個問題。 這並沒有解決問題。

  2. 發現Python 2.7.9從Python 3向后移植了一些SSL庫。我從Python 2.7.6升級到2.7.9,假設更新(包括此線程中列出的修復程序: https//serverfault.com/questions/692110/錯誤-python2-as-a-https-client-with-an-nginx-server-and-ssl-certificate-ch )會解決它。 沒有運氣,同樣的錯誤。

  3. 顯然設置verify=False有效,但我們不願意在安全方面做出讓步,我們需要得到verify=True才能工作。

  4. curl https://google.com也按預期工作。 這就是我知道它與Python有關的方式。

環境

$ python -V
Python 2.7.9

$ pip list | grep -e requests
requests (2.9.1)

$ uname-a  # ubuntu 14.04
Linux staging.example.com 3.13.0-48-generic #80-Ubuntu SMP Thu Mar 12 11:16:15 UTC 2015 x86_64 x86_64 x86_64 GNU/Linux

適用於https上的Google域名。 這是一個例子:

$ ipython
Python 2.7.9 (default, Jan  6 2016, 21:37:32)
Type "copyright", "credits" or "license" for more information.

IPython 4.0.1 -- An enhanced Interactive Python.
?         -> Introduction and overview of IPython's features.
%quickref -> Quick reference.
help      -> Python's own help system.
object?   -> Details about 'object', use 'object??' for extra details.

In [1]: import requests

In [2]: requests.get('https://facebook.com', verify=True)
Out[2]: <Response [200]>

In [3]: requests.get('https://stackoverflow.com', verify=True)
Out[3]: <Response [200]>

In [4]: requests.get('https://spotify.com', verify=True)
Out[4]: <Response [200]>

In [5]: requests.get('http://google.com', verify=True) # notice the http
Out[5]: <Response [200]>

In [6]: requests.get('https://google.com', verify=True)
---------------------------------------------------------------------------
SSLError                                  Traceback (most recent call last)
<ipython-input-6-a7fff1831944> in <module>()
----> 1 requests.get('https://google.com', verify=True)

/example/.virtualenv/example/lib/python2.7/site-packages/requests/api.pyc in get(url, params, **kwargs)
     65
     66     kwargs.setdefault('allow_redirects', True)
---> 67     return request('get', url, params=params, **kwargs)
     68
     69

/example/.virtualenv/example/lib/python2.7/site-packages/requests/api.pyc in request(method, url, **kwargs)
     51     # cases, and look like a memory leak in others.
     52     with sessions.Session() as session:
---> 53         return session.request(method=method, url=url, **kwargs)
     54
     55

/example/.virtualenv/example/lib/python2.7/site-packages/requests/sessions.pyc in request(self, method, url, params, data, headers, cookies, files, auth, timeout, allow_redirects, proxies, hooks, stream, verify, cert, json)
    466         }
    467         send_kwargs.update(settings)
--> 468         resp = self.send(prep, **send_kwargs)
    469
    470         return resp

/example/.virtualenv/example/lib/python2.7/site-packages/requests/sessions.pyc in send(self, request, **kwargs)
    574
    575         # Send the request
--> 576         r = adapter.send(request, **kwargs)
    577
    578         # Total elapsed time of the request (approximately)

/example/.virtualenv/example/lib/python2.7/site-packages/requests/adapters.pyc in send(self, request, stream, timeout, verify, cert, proxies)
    445         except (_SSLError, _HTTPError) as e:
    446             if isinstance(e, _SSLError):
--> 447                 raise SSLError(e, request=request)
    448             elif isinstance(e, ReadTimeoutError):
    449                 raise ReadTimeout(e, request=request)

SSLError: ("bad handshake: Error([('SSL routines', 'SSL3_GET_SERVER_CERTIFICATE', 'certificate verify failed')],)",)

我找到了解決方案。 在運行的certifi版本中似乎存在一個主要問題。 我從這個(非常長的)GitHub問題中找到了這個: https//github.com/certifi/python-certifi/issues/26

TL; DR

pip uninstall -y certifi && pip install certifi==2015.04.28

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM