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