> 技术文档 > [快速完美]解决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]_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啦!

穿衣搭配技巧