-->
当前位置:首页 > DayDayUp > 正文内容

python requests SSL认证不过导致失败

Luz4年前 (2022-01-04)DayDayUp5897

request请求https报错:

  1. >>> requests.get('https://33.157.0.114:8321/encryptDogService/dogInfo/base')
  2. Traceback (most recent call last):
  3.   File "C:\ProgramData\Anaconda3\lib\site-packages\urllib3\connectionpool.py", line 699, in urlopen
  4.     httplib_response = self._make_request(
  5.   File "C:\ProgramData\Anaconda3\lib\site-packages\urllib3\connectionpool.py", line 382, in _make_request
  6.     self._validate_conn(conn)
  7.   File "C:\ProgramData\Anaconda3\lib\site-packages\urllib3\connectionpool.py", line 1010, in _validate_conn
  8.     conn.connect()
  9.   File "C:\ProgramData\Anaconda3\lib\site-packages\urllib3\connection.py", line 411, in connect
  10.     self.sock = ssl_wrap_socket(
  11.   File "C:\ProgramData\Anaconda3\lib\site-packages\urllib3\util\ssl_.py", line 432, in ssl_wrap_socket
  12.     ssl_sock = _ssl_wrap_socket_impl(sock, context, tls_in_tls)
  13.   File "C:\ProgramData\Anaconda3\lib\site-packages\urllib3\util\ssl_.py", line 474, in _ssl_wrap_socket_impl
  14.     return ssl_context.wrap_socket(sock)
  15.   File "C:\ProgramData\Anaconda3\lib\ssl.py", line 500, in wrap_socket
  16.     return self.sslsocket_class._create(
  17.   File "C:\ProgramData\Anaconda3\lib\ssl.py", line 1040, in _create
  18.     self.do_handshake()
  19.   File "C:\ProgramData\Anaconda3\lib\ssl.py", line 1309, in do_handshake
  20.     self._sslobj.do_handshake()
  21. ssl.SSLCertVerificationError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: self signed certificate in certificate chain (_ssl.c:1125)
  22.  
  23. During handling of the above exception, another exception occurred:
  24.  
  25. Traceback (most recent call last):
  26.   File "C:\ProgramData\Anaconda3\lib\site-packages\requests\adapters.py", line 439, in send
  27.     resp = conn.urlopen(
  28.   File "C:\ProgramData\Anaconda3\lib\site-packages\urllib3\connectionpool.py", line 755, in urlopen
  29.     retries = retries.increment(
  30.   File "C:\ProgramData\Anaconda3\lib\site-packages\urllib3\util\retry.py", line 574, in increment
  31.     raise MaxRetryError(_pool, url, error or ResponseError(cause))
  32. urllib3.exceptions.MaxRetryError: HTTPSConnectionPool(host='33.157.0.114', port=8321): Max retries exceeded with url: /encryptDogService/dogInfo/base (Caused by SSLError(SSLCertVerificationError(1, '[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: self signed certificate in certificate chain (_ssl.c:1125)')))
  33.  
  34. During handling of the above exception, another exception occurred:
  35.  
  36. Traceback (most recent call last):
  37.   File "<stdin>", line 1, in <module>
  38.   File "C:\ProgramData\Anaconda3\lib\site-packages\requests\api.py", line 75, in get
  39.     return request('get', url, params=params, **kwargs)
  40.   File "C:\ProgramData\Anaconda3\lib\site-packages\requests\api.py", line 61, in request
  41.     return session.request(method=method, url=url, **kwargs)
  42.   File "C:\ProgramData\Anaconda3\lib\site-packages\requests\sessions.py", line 542, in request
  43.     resp = self.send(prep, **send_kwargs)
  44.   File "C:\ProgramData\Anaconda3\lib\site-packages\requests\sessions.py", line 655, in send
  45.     r = adapter.send(request, **kwargs)
  46.   File "C:\ProgramData\Anaconda3\lib\site-packages\requests\adapters.py", line 514, in send
  47.     raise SSLError(e, request=request)
  48. requests.exceptions.SSLError: HTTPSConnectionPool(host='33.157.0.114', port=8321): Max retries exceeded with url: /encryptDogService/dogInfo/base (Caused by SSLError(SSLCertVerificationError(1, '[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: self signed certificate in certificate chain (_ssl.c:1125)')))

解决方法:

请求时加上

  1. verify=False
  1. >>> requests.get('https://33.157.0.114:8321/encryptDogService/dogInfo/base',verify=False).text
  2. '{"currentTime":"20220104T014236Z","expireDate":"2022-06-17","totalCount":1,"version":"VSL_3.0_20200320_XX"}\n'

补充:

加完以后不报错了,但是会在命令行里弹警告

  1. InsecureRequestWarning: unverified HTTPS request is being made to host

影响观感,需要加上:

  1. import urllib3
  2. urllib3.disable_warnings()

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。