如何在客户端对Python请求使用证书和密钥文件?

如何在客户端对Python请求使用证书和密钥文件?,python,https,python-requests,Python,Https,Python Requests,我有一个家庭作业,在那里我必须与服务器通信。我正在完成最后一项任务,但我无法使它工作。任务如下: 连接到http://[Server IP]并下载cert.php和key.php文件 之后,使用这些文件获取https://[Server IP] 如果HTTPS请求成功,服务器将使用unique标志进行回复。(卫生福利署的解决方案) 我可以毫无问题地下载这些文件,但当我尝试使用它们时,会出现错误: Traceback (most recent call last): File "

我有一个家庭作业,在那里我必须与服务器通信。我正在完成最后一项任务,但我无法使它工作。任务如下:

  • 连接到http://[Server IP]并下载cert.php和key.php文件
  • 之后,使用这些文件获取https://[Server IP]
  • 如果HTTPS请求成功,服务器将使用unique标志进行回复。(卫生福利署的解决方案)
我可以毫无问题地下载这些文件,但当我尝试使用它们时,会出现错误:

Traceback (most recent call last):
  File "C:\Users\user\PycharmProjects\pythonProject\venv\lib\site-packages\urllib3\connectionpool.py", line 699, in urlopen
    httplib_response = self._make_request(
  File "C:\Users\user\PycharmProjects\pythonProject\venv\lib\site-packages\urllib3\connectionpool.py", line 382, in _make_request
    self._validate_conn(conn)
  File "C:\Users\user\PycharmProjects\pythonProject\venv\lib\site-packages\urllib3\connectionpool.py", line 1010, in _validate_conn
    conn.connect()
  File "C:\Users\user\PycharmProjects\pythonProject\venv\lib\site-packages\urllib3\connection.py", line 411, in connect
    self.sock = ssl_wrap_socket(
  File "C:\Users\user\PycharmProjects\pythonProject\venv\lib\site-packages\urllib3\util\ssl_.py", line 432, in ssl_wrap_socket
    ssl_sock = _ssl_wrap_socket_impl(sock, context, tls_in_tls)
  File "C:\Users\user\PycharmProjects\pythonProject\venv\lib\site-packages\urllib3\util\ssl_.py", line 474, in _ssl_wrap_socket_impl
    return ssl_context.wrap_socket(sock)
  File "C:\Users\user\AppData\Local\Programs\Python\Python39\lib\ssl.py", line 500, in wrap_socket
    return self.sslsocket_class._create(
  File "C:\Users\user\AppData\Local\Programs\Python\Python39\lib\ssl.py", line 1040, in _create
    self.do_handshake()
  File "C:\Users\user\AppData\Local\Programs\Python\Python39\lib\ssl.py", line 1309, in do_handshake
    self._sslobj.do_handshake()
ssl.SSLCertVerificationError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: self signed certificate (_ssl.c:1122)

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "C:\Users\user\PycharmProjects\pythonProject\venv\lib\site-packages\requests\adapters.py", line 439, in send
    resp = conn.urlopen(
  File "C:\Users\user\PycharmProjects\pythonProject\venv\lib\site-packages\urllib3\connectionpool.py", line 755, in urlopen
    retries = retries.increment(
  File "C:\Users\user\PycharmProjects\pythonProject\venv\lib\site-packages\urllib3\util\retry.py", line 574, in increment
    raise MaxRetryError(_pool, url, error or ResponseError(cause))
urllib3.exceptions.MaxRetryError: HTTPSConnectionPool(host='152.66.249.144', port=443): Max retries exceeded with url: / (Caused by SSLError(SSLCertVerificationError(1, '[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: self signed certificate (_ssl.c:1122)')))

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "C:\Users\user\PycharmProjects\pythonProject\HF\hf_script.py", line 195, in <module>
    final_conn = requests.get(url_https,
  File "C:\Users\user\PycharmProjects\pythonProject\venv\lib\site-packages\requests\api.py", line 76, in get
    return request('get', url, params=params, **kwargs)
  File "C:\Users\user\PycharmProjects\pythonProject\venv\lib\site-packages\requests\api.py", line 61, in request
    return session.request(method=method, url=url, **kwargs)
  File "C:\Users\user\PycharmProjects\pythonProject\venv\lib\site-packages\requests\sessions.py", line 542, in request
    resp = self.send(prep, **send_kwargs)
  File "C:\Users\user\PycharmProjects\pythonProject\venv\lib\site-packages\requests\sessions.py", line 655, in send
    r = adapter.send(request, **kwargs)
  File "C:\Users\user\PycharmProjects\pythonProject\venv\lib\site-packages\requests\adapters.py", line 514, in send
    raise SSLError(e, request=request)
requests.exceptions.SSLError: HTTPSConnectionPool(host='152.66.249.144', port=443): Max retries exceeded with url: / (Caused by SSLError(SSLCertVerificationError(1, '[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: self signed certificate (_ssl.c:1122)')))

Process finished with exit code 1

好的,我明白了。我怀疑有人会使用这个,但我使用的证书和密钥很好,问题是,服务器本身使用的是自签名证书,我必须建立连接。对我有效的解决方案是:

final_conn = requests.get(url_https,
                          cert=('C:/Users/user/PycharmProjects/pythonProject/HF/cert.php',
                                'C:/Users/user/PycharmProjects/pythonProject/HF/key.php'),
                          verify=False)
final_conn = requests.get(url_https,
                          cert=('C:/Users/user/PycharmProjects/pythonProject/HF/cert.php',
                                'C:/Users/user/PycharmProjects/pythonProject/HF/key.php'),
                          verify=False)