Python2.7.9 之后,当使用urllib.urlopen打开一个 https 链接时,会验证一次 SSL 证书。而当目标网站使用的是自签名的证书时就会抛出如下异常:
<urlopen error [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:777)>
解决办法如下
1,方案一
使用ssl创建未经验证的上下文,在urlopen中传入上下文参数:
import ssl context = ssl._create_unverified_context() urllib.request.urlopen(req,context=context)
2,方案二
全局取消证书验证:
import ssl ssl._create_default_https_context = ssl._create_unverified_context urllib2.urlopen("https://www.12306.cn/mormhweb/").read()
3,方案三
使用的是requests模块,将方法中的verify设置位False即可:
requests.get(url, headers=Hostreferer,verify=False)
常见问题FAQ
- 免费下载或者VIP会员专享资源能否直接商用?
- 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
- 提示下载完但解压或打开不了?
- 找不到素材资源介绍文章里的示例图片?
- 模板不会安装或需要功能定制以及二次开发?
发表评论
还没有评论,快来抢沙发吧!