[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: unable to get local issuer certificate (_ssl.c:1002)
时间: 2023-10-31 09:58:00 浏览: 229
ssl.zip_c ssl_c语言 openssl_linux openssl_site:www.pudn.com
当出现[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: unable to get local issuer certificate (_ssl.c:1002)的报错信息时,这通常表示无法获取本地签发者证书。这可能是因为网站使用了自签名证书或系统根证书存在问题。
解决这个问题的一种方法是使用`certifi`库提供的CA证书来进行验证。首先,你需要导入`certifi`和`urllib`模块:
```python
import certifi
import urllib
```
然后,你可以使用`urllib.request.urlopen()`函数的`cafile`参数来指定CA证书的路径,例如:
```python
urllib.request.urlopen('https://example.com/bar/baz.html', cafile=certifi.where())
```
这将使用`certifi`库提供的CA证书来进行证书验证。
除了使用`certifi`库提供的CA证书外,你还可以全局取消证书验证。可以使用`ssl`模块的`_create_default_https_context`函数来取消证书验证,示例如下:
```python
import ssl
ssl._create_default_https_context = ssl._create_unverified_context
```
这将取消对证书的验证,但也可能降低安全性。在使用此方法时,请确保你信任要访问的网站。
综上所述,解决[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: unable to get local issuer certificate (_ssl.c:1002)的方法包括使用`certifi`库提供的CA证书进行验证或全局取消证书验证。你可以根据具体情况选择适合你的方法来解决这个问题。
阅读全文