首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用urllib3忽略证书验证

使用urllib3忽略证书验证
EN

Stack Overflow用户
提问于 2013-08-05 15:13:37
回答 4查看 45.7K关注 0票数 24

我正在对具有自签名证书的私有服务使用urllib3。是否有任何方法让urllib3忽略证书错误并提出请求?

代码语言:javascript
复制
import urllib3
c = urllib3.HTTPSConnectionPool('10.0.3.168', port=9001)
c.request('GET', '/')

在使用以下内容时:

代码语言:javascript
复制
import urllib3
c = urllib3.HTTPSConnectionPool('10.0.3.168', port=9001, cert_reqs='CERT_NONE')
c.request('GET', '/')

引发以下错误:

代码语言:javascript
复制
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/usr/lib/python3/dist-packages/urllib3/request.py", line 67, in request
    **urlopen_kw)
  File "/usr/lib/python3/dist-packages/urllib3/request.py", line 80, in request_encode_url
    return self.urlopen(method, url, **urlopen_kw)
  File "/usr/lib/python3/dist-packages/urllib3/connectionpool.py", line 415, in urlopen
    body=body, headers=headers)
  File "/usr/lib/python3/dist-packages/urllib3/connectionpool.py", line 267, in _make_request
    conn.request(method, url, **httplib_request_kw)
  File "/usr/lib/python3.3/http/client.py", line 1061, in request
    self._send_request(method, url, body, headers)
  File "/usr/lib/python3.3/http/client.py", line 1099, in _send_request
    self.endheaders(body)
  File "/usr/lib/python3.3/http/client.py", line 1057, in endheaders
    self._send_output(message_body)
  File "/usr/lib/python3.3/http/client.py", line 902, in _send_output
    self.send(msg)
  File "/usr/lib/python3.3/http/client.py", line 840, in send
    self.connect()
  File "/usr/lib/python3/dist-packages/urllib3/connectionpool.py", line 103, in connect
    match_hostname(self.sock.getpeercert(), self.host)
  File "/usr/lib/python3/dist-packages/urllib3/packages/ssl_match_hostname/__init__.py", line 32, in match_hostname
    raise ValueError("empty or no certificate")
ValueError: empty or no certificate

使用cURL,我能够从服务中获得预期的响应

代码语言:javascript
复制
$ curl -k https://10.0.3.168:9001/
Please read the documentation for API endpoints
EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2013-08-05 15:45:52

尝试使用以下代码:

代码语言:javascript
复制
import urllib3
c = urllib3.HTTPSConnectionPool('10.0.3.168', port=9001, cert_reqs='CERT_NONE',
                                assert_hostname=False)
c.request('GET', '/')

请参阅主机名为False将禁用SSL主机名验证。

票数 19
EN

Stack Overflow用户

发布于 2021-02-16 08:20:03

在这个问题上,我看到了很多答案,但是,IMHO,太多不必要的信息会导致混乱。

cert_reqs='CERT_NONE' 只添加参数

代码语言:javascript
复制
import urllib3
http = urllib3.PoolManager(cert_reqs='CERT_NONE')
票数 8
EN

Stack Overflow用户

发布于 2020-06-30 22:08:35

我找到了我的问题的答案。事实上,urllib3文档并没有完全解释如何禁止SSL证书验证。缺少的是对ssl.CERT_NONE的引用。

我的代码有一个布尔值,ssl_verify,用于指示是否需要SSL验证。代码现在如下所示:

代码语言:javascript
复制
import ssl
import urllib3

#
#
#
    if (ssl_verify):
        cert_reqs = ssl.CERT_REQUIRED
    else:
        cert_reqs = ssl.CERT_NONE
        urllib3.disable_warnings()

    http = urllib3.PoolManager(cert_reqs = cert_reqs)

    auth_url = f'https://{fmc_ip}/api/fmc_platform/v1/auth/generatetoken'
    type = {'Content-Type': 'application/json'}

    auth = urllib3.make_headers(basic_auth=f'{username}:{password}')
    headers = { **type, **auth }

    resp = http.request('POST',
                    auth_url,
                    headers=headers,
                    timeout=10.0)
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18061640

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档