我在用

import requests
requests.post(url='https://foo.example', data={'bar':'baz'})

但是我得到一个request。exceptions。sslerror。 网站的证书过期了,但我没有发送敏感数据,所以这对我来说无关紧要。 我可以想象有一个像“verify =False”这样的参数,我可以使用,但我似乎找不到它。


当前回答

什么对我有效Due verify=False Bug

由于会话上的错误。验证=False,使urllib*忽略 当设置环境变量(CURL_CA_BUNDLE)时。所以我们把它设为零。

import requests, os
session = requests.Session()
session.verify = False
session.trust_env = False
os.environ['CURL_CA_BUNDLE']="" # or whaever other is interfering with 
session.post(url='https://example.com', data={'bar':'baz'})

不确定我是否需要trust_env

其他回答

如果你想准确地发送带有verify=False选项的post请求,最快的方法是使用以下代码:

import requests

requests.api.request('post', url, data={'bar':'baz'}, json=None, verify=False)

在请求方法上使用requests.packages.urllib3.disable_warnings()和verify=False。

import requests
from urllib3.exceptions import InsecureRequestWarning

# Suppress only the single warning from urllib3 needed.
requests.packages.urllib3.disable_warnings(category=InsecureRequestWarning)

# Set `verify=False` on `requests.post`.
requests.post(url='https://example.com', data={'bar':'baz'}, verify=False)

什么对我有效Due verify=False Bug

由于会话上的错误。验证=False,使urllib*忽略 当设置环境变量(CURL_CA_BUNDLE)时。所以我们把它设为零。

import requests, os
session = requests.Session()
session.verify = False
session.trust_env = False
os.environ['CURL_CA_BUNDLE']="" # or whaever other is interfering with 
session.post(url='https://example.com', data={'bar':'baz'})

不确定我是否需要trust_env

python 3 + 6。

import warnings
warnings.filterwarnings("ignore", message="Unverified HTTPS request")

也可以使用环境变量:

export CURL_CA_BUNDLE=""