Python 升级到 2.7.9 之后引入了一个新特性,当使用urllib.urlopen打开一个 https 链接时,会验证一次 SSL 证书。而当目标网站使用的是自签名的证书时就会抛出此异常。
解决方案有如下两个:
1)使用ssl创建未经验证的上下文,在urlopen中传入上下文参数
import ssl
context = ssl._create_unverified_context()
response = urllib.request.urlopen(req,context=context)
2)全局取消证书验证
import ssl
ssl._create_default_https_context = ssl._create_unverified_context
另外,如果用的是requests模块的get方法,里面有一个verify参数,将其设成False就可以了。