我正在尝试使用 Python 从内部服务器下载一些数据。由于它是内部的,因此它使用自签名证书。 (我们不想为永远不会出现在“野外”的服务器付费。)Python 2.6 版本的代码运行良好。
response = urllib2.urlopen(URL)
data = csv.reader(response)
我现在正在尝试更新到 Python 3.4(长话短说,不要问。)但是,使用 Python 3 的 urllib 失败:
response = urllib.request.urlopen(URL)
它会引发 CERTIFICATE_VERIFY_FAILED 错误。
urllib.error.URLError: <urlopen error [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:600)>
在网上阅读时,显然 Python 2.6 urllib2 不费心去验证证书。 urllib 的某些版本允许将“verify=False”传递给方法签名,但这似乎在 Python 3.4 中不起作用。
有谁知道我该如何解决这个问题?由于公司安全准则,我想避免使用 Requests 包。
使用以下内容禁用 URL 的 SSL 证书验证
import ssl
myssl = ssl.create_default_context();
myssl.check_hostname=False
myssl.verify_mode=ssl.CERT_NONE
urlopen("URL",context=myssl)
使用以下命令禁用所有 URL 的 SSL 证书验证
ssl._create_default_https_context = ssl._create_unverified_context
urlopen("URL");
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)