Python-urllib和“ SSL:CERTIFICATE_VERIFY_FAILED”错误

Python-urllib和“ SSL:CERTIFICATE_VERIFY_FAILED”错误,第1张

Python-urllib和“ SSL:CERTIFICATE_VERIFY_FAILED”错误

如果只想绕过验证,则可以创建一个新的

SSLContext
默认情况下,新创建的上下文使用
CERT_NONE

请注意第17.3.7.2.1节中的规定

直接调用

SSLContext
构造函数时,默认值为
CERT_NONE
。由于它不对另一个对等方进行身份验证,因此它可能是不安全的,尤其是在客户端模式下,在大多数情况下,你希望确保与之对话的服务器的真实性。因此,在客户端模式下,强烈建议使用
CERT_REQUIRED

但是,如果你只是希望它由于其他原因而现在可以工作,则可以执行以下 *** 作,则还必须这样

import ssl
做:

input = input.replace("!web ", "")      url = "https://domainsearch.p.mashape.com/index.php?name=" + inputreq = urllib2.Request(url, headers={ 'X-Mashape-Key': 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX' })gcontext = ssl.SSLContext()  # only for gangstarsinfo = urllib2.urlopen(req, context=gcontext).read()Message.Chat.SendMessage ("" + info)

这应该可以解决你的问题,但是你并没有真正解决任何问题,但是你不会看到,[SSL: CERTIFICATE_VERIFY_FAILED]因为你现在不在验证证书!

补充说明一下,如果你想了解更多有关为什么看到这些问题的信息,请参阅PEP 476。

该PEP建议默认情况下启用X509证书签名的验证以及Python HTTP客户端的主机名验证,但需要根据每次调用选择退出。此更改将应用​​于Python 2.7,Python 3.4和Python 3.5。

有一个建议的退出选项,与我上面的建议没有什么不同:

import ssl# This restores the same behavior as before.context = ssl._create_unverified_context()urllib.urlopen("https://no-valid-cert", context=context)

它还通过Monkeypatching提供了一个不鼓励使用的选项,这在python中并不常见:

import sslssl._create_default_https_context = ssl._create_unverified_context

它将使用创建未验证上下文的功能覆盖用于上下文创建的默认功能。

请注意,如PEP中所述:

本指南主要针对希望采用较新版本的Python的系统管理员,这些版本的Python在尚不支持HTTPS连接证书验证的传统环境中实现此PEP。例如,管理员可以通过在其Python标准 *** 作环境中将上述Monkeypatch添加到sitecustomize.py中来选择退出。应用程序和库不应在整个更改过程中进行更改(除非响应系统管理员控制的配置设置)。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/4980510.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-14
下一篇 2022-11-14

发表评论

登录后才能评论

评论列表(0条)

保存