[快速完美]解决urllib.error.URLError: <urlopen error [SSL: CERTIFICATE_VERIFY_FAILED]_urllib.error.urlerror: <urlopen error [errno 99] c
完整报错信息
urllib.error.URLError: <urlopen error [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed
本质原因:ssl 本地证书不存在
解决方法:
一、解决思路:使用ssl._create_unverified_context
关闭认证
可以参考 python解决urllib发送请求报错:urllib.error.URLError: <urlopen error [SSL: CERTIFICATE_VERIFY_FAILED].....>_urllib.error.urlerror: <urlopen error [ssl: certif-CSDN博客
但是有时候会存在代码结构太过复杂,很难一下子找到对应的代码段进行添加,这时候就可以直接尝试方法二
二 、解决思路:下载更新的证书,并进行替换,一步到位
①查看ssl证书默认位置
import sslprint(ssl.get_default_verify_path())
执行结果可以看到
DefaultVerifyPaths(cafile=None, capath=None, openssl_cafile_env=\'SSL_CERT_FILE\', openssl_cafile=\'/home/qtt/software/anaconda/envs/mamba_torch2.0.1/ssl/cert.pem\', openssl_capath_env=\'SSL_CERT_DIR\', openssl_capath=\'/home/qtt/software/anaconda/envs/mamba_torch2.0.1/ssl/certs\')
cafile=None,显示证书不存在,但是进入 openssl_cafile路径下又可以看到cacert.pem文件,推测可能是什么原因导致不识别。
②下载ca文件
http://curl.haxx.se/ca/cacert.pem
下载好新cacert.pem文件后,放入上面的openssl_cafile路径下,进行替换。
再运行代码就ok啦!