Python 升级到 2.7.9 以后引入了一个新特性,当使用urllib.urlopen打开一个 https 连接时,会验证一次 SSL 证书。而当目标网站使用的是自签名的证书时就会抛出一个 urllib2.URLError: <urlopen error [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed> 的错误消息,详细信息能够在这里查看(https://www.python.org/dev/peps/pep-0476/)。python
解决方案包括下列两种方式:网站
1. 使用ssl建立未经验证的上下文,在urlopen中传入上下文参数url
import ssl import urllib2 context = ssl._create_unverified_context() print urllib2.urlopen("https://www.xxx.cn/", context=context).read()
2. 全局取消证书验证spa
import ssl import urllib2 ssl._create_default_https_context = ssl._create_unverified_context print urllib2.urlopen("https://www.xxx/").read()