有些网页,一开始用脚本语言(python)去访问的时候会遇到这样问题。
一般这样的网站用浏览器去访问的时候,会弹出这样的警告“您的链接不是私密链接”。
内容大多出自于崔大神书籍。本菜结合书中内容做了自己的阐述。
这里是由于这个网页的证书没有被官方CA机构信任,所以这里会出现证书验证的错误。
这样的url典型有
https://www.12306.cn
如下使用代码的时候
,就会出现这样的问题。
import requests
r = requests.get('https://www.12306.cn')
print(r.status_code)
第一种解决方法
**解释:**下面代码有点意思。一开始的时候写在pycharm上面显示的是错误的信息。但是运气起来却是没有问题的。
下面代码调用了urllib3.disable_warnings()函数,来确保不会发生警告。
import requests
from requests.packages import urllib3
urllib3.disable_warnings()
r = requests.get('https://www.12306.cn', verify=False)
print(r.status_code)
如果不写 urllib3.disable_warnings(),看下面代码
import requests
# from requests.packages import urllib3
# urllib3.disable_warnings()
r = requests.get('https://www.12306.cn', verify=False)
print(r.status_code)
输出如下
下面内容中
是对应的路径。
Path\urllib3\connectionpool.py:858: InsecureRequestWarning: Unverified HTTPS request is being made. Adding certificate verification is strongly advised. See: https://urllib3.readthedocs.io/en/latest/advanced-usage.html#ssl-warnings
InsecureRequestWarning)
解决办法2:
import requests
import logging
logging.captureWarnings(True)
r = requests.get('https://www.12306.cn', verify=False)
print(r.status_code)
内容大多为学习笔记。能帮到更多人当然更好。也就不放二维码之类的东西了。致敬
前提有些网页,一开始用脚本语言(python)去访问的时候会遇到这样问题。 一般这样的网站用浏览器去访问的时候,会弹出这样的警告“您的链接不是私密链接”。 内容大多出自于崔大神书籍。本菜结合书中内容做了自己的阐述。简单解释这里是由于这个网页的证书没有被官方CA机构信任,所以这里会出现证书验证的错误。 这样的url典型有https://www.12306.cn如下使用代...
解决requests.exceptions.ProxyError: (MaxRetryError(“HTTPSConnectionPool(host=‘huggingface.co‘, port=
requests.exceptions.SSLError: HTTPSConnectionPool(host='martin-audio.com', port=443):
Max retries exceeded with url: xxx (Caused by SSLError(SSLError("bad handshake: Error
([('SSL routines', 'ssl3_get_se.
requests.exceptions.ConnectionError:
HTTPSConnectionPool(host='127.0.0.1', port=443):
Max retries exceeded with url:
/?cdn=nohost (Caused by NewConnectionError('<urllib3.connection.VerifiedHTTP...
`requests.exceptions.SSLError: HTTPSConnectionPool(host='www.baidu.com', port=443): Max retries exceeded with url: / (Caused by SSLError(SSLError(1, u'[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:581)'),))`是一个常见的错误,它表示在使用`requests`库发送HTTPS请求时发生了SSL证书验证失败的错误。
这个错误通常是由于以下原因之一引起的:
1. 服务器的SSL证书无效或过期。
2. 客户端没有正确配置SSL证书验证。
为了解决这个问题,你可以尝试以下方法之一:
1. 忽略SSL证书验证错误:
```python
import requests
requests.packages.urllib3.disable_warnings() # 禁用SSL警告
response = requests.get('https://www.baidu.com', verify=False) # 忽略SSL证书验证
print(response.text)
2. 使用自定义的SSL证书:
```python
import requests
response = requests.get('https://www.baidu.com', cert='/path/to/certificate.pem') # 使用自定义的SSL证书
print(response.text)
请注意,忽略SSL证书验证错误可能会导致安全风险,请谨慎使用。