2017-03-27 1 views
0

J'ai un problème très similaire à celui discuté herecertificat ssl vérifier fonctionne apparemment avec le client ssl mais pas avec urllib3

J'utilise python 3.4 avec bibliothèque urllib3.

Lorsque je teste le code ci-dessous, je reçois:

Traceback (most recent call last): 
File "/home/julimatt/zibawa3/zib3/lib/python3.4/site-packages/requests/packages/urllib3/connectionpool.py", line 600, in urlopen 
    chunked=chunked) 
    File "/home/julimatt/zibawa3/zib3/lib/python3.4/site-packages/requests/packages/urllib3/connectionpool.py", line 345, in _make_request 
    self._validate_conn(conn) 
    File "/home/julimatt/zibawa3/zib3/lib/python3.4/site-packages/requests/packages/urllib3/connectionpool.py", line 844, in _validate_conn 
    conn.connect() 
    File "/home/julimatt/zibawa3/zib3/lib/python3.4/site-packages/requests/packages/urllib3/connection.py", line 326, in connect 
    ssl_context=context) 
    File "/home/julimatt/zibawa3/zib3/lib/python3.4/site-packages/requests/packages/urllib3/util/ssl_.py", line 324, in ssl_wrap_socket 
    return context.wrap_socket(sock, server_hostname=server_hostname) 
    File "/usr/lib/python3.4/ssl.py", line 364, in wrap_socket 
    _context=self) 
    File "/usr/lib/python3.4/ssl.py", line 578, in __init__ 
    self.do_handshake() 
    File "/usr/lib/python3.4/ssl.py", line 805, in do_handshake 
    self._sslobj.do_handshake() 
ssl.SSLError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:598) 

During handling of the above exception, another exception occurred: 

Traceback (most recent call last): 
    File "/home/julimatt/zibawa3/zib3/lib/python3.4/site-packages/requests/adapters.py", line 423, in send 
    timeout=timeout 
    File "/home/julimatt/zibawa3/zib3/lib/python3.4/site-packages/requests/packages/urllib3/connectionpool.py", line 630, in urlopen 
    raise SSLError(e) 
requests.packages.urllib3.exceptions.SSLError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:598) 

During handling of the above exception, another exception occurred: 

Traceback (most recent call last): 
    File "/home/julimatt/workspace2/zibawa/stack_configs/tests.py", line 44, in test_bind_grafana 
    result=getFromGrafanaApi(apiurl, data,'GET') 
    File "/home/julimatt/workspace2/zibawa/stack_configs/models.py", line 317, in getFromGrafanaApi 
    verify=ca_certs, 
    File "/home/julimatt/zibawa3/zib3/lib/python3.4/site-packages/requests/sessions.py", line 609, in send 
    r = adapter.send(request, **kwargs) 
    File "/home/julimatt/zibawa3/zib3/lib/python3.4/site-packages/requests/adapters.py", line 497, in send 
    raise SSLError(e, request=request) 
requests.exceptions.SSLError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:598) 

Mon code est:

from requests import Request, Session 
ca_certs='/path/to/letsencypt/fullchain.pem' 
url= 'https://myserver.com:3000/api/org' 

username= settings.DASHBOARD['user'] 
password= settings.DASHBOARD['password'] 

headers = {'Accept': 'application/json', 
       'Content-Type' : 'application/json',} 

s = Session() 
req = Request('GET', url, data=data, headers=headers, auth=(username,password)) 

prepped = s.prepare_request(req) 

resp = s.send(prepped, 
verify=ca_certs, 

) 

print(resp.status_code) 
return resp 

Si je teste mon code avec 'vérifier = False' dans la demande, il fonctionne bien mais ce n'est évidemment pas une solution sûre.

J'ai essayé de tester ma connexion ssl depuis un terminal sur la même machine en utilisant:

openssl s_client -connect myserver.com:3000 -CAfile /path/to/letsencypt/fullchain.pem 

Puis-je obtenir une poignée de main succesful. Donc, je ne comprends pas pourquoi je reçois cette erreur.

Merci d'avance pour toute aide que vous pouvez fournir.

Répondre

0

Je n'avais pas compris le certificat racine à utiliser et j'avais plutôt utilisé les certificats intermédiaires.

SOLUTION:

Après l'aide de la communauté letsencrypt j'ai copié la DST Root CA X3 à partir https://www.identrust.com/certificates/trustid/root-download-x3.html. J'ai aussi dû ajouter les lignes "----- BEGIN CERTIFICATE -----" et "----- END CERTIFICATE -----" à mon dossier. Puis, en enregistrant ce fichier, j'ai pu définir "ca_certs" pour pointer vers ce fichier lors de l'appel de l'API à partir de python et "verify_certs" fonctionne maintenant.