我正在尝试使用 Python 3 asyncio 模块连接到另一方并收到此错误:
36 sslcontext = ssl.SSLContext(ssl.PROTOCOL_TLSv1)
---> 37 sslcontext.load_cert_chain(cert, keyfile=ca_cert)
38
SSLError: [SSL] PEM lib (_ssl.c:2532)
问题是错误的含义。我的证书是正确的, key 文件(CA 证书)可能不正确。
最佳答案
假设使用的是 3.6 版:
见:https://github.com/python/cpython/blob/3.6/Modules/_ssl.c#L3523-L3534
PySSL_BEGIN_ALLOW_THREADS_S(pw_info.thread_state);
r = SSL_CTX_check_private_key(self->ctx);
PySSL_END_ALLOW_THREADS_S(pw_info.thread_state);
if (r != 1) {
_setSSLError(NULL, 0, __FILE__, __LINE__);
goto error;
}
它的意思是 SSL_CTX_check_private_key
失败;因此,私钥不正确。
引用可能的版本:
关于python - "SSLError: [SSL] PEM lib (_ssl.c:2532)"是什么意思使用 Python ssl 库?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30109449/