问:为什么要写这个文章?
答:因为有一些用户在某些机器运行SDK或者自己拼包等发生了SSL验证的问题,为了解决大家的这个问题,总结本文。
Urllib部分
解决方法1:
使用ssl创建未经验证的上下文,在urlopen中传入上下文参数
代码语言:javascript复制import ssl
import urllib2
context = ssl._create_unverified_context()
print urllib2.urlopen("https://cvm.tencentcloudapi.com/", context=context).read()
解决方法2:
导入ssl时关闭证书验证
代码语言:javascript复制import ssl
import urllib2
ssl._create_default_https_context = ssl._create_unverified_context
print urllib2.urlopen("https://cvm.tencentcloudapi.com/").read()
python3的话,适当修改一下urllib就可以了。
requests部分
解决方法1:
通过 verify 指定证书,表示相信此证书;也可以用 verify=False,表示不验证服务器端的证书。
代码语言:javascript复制#!/bin/env python
import requests
url = "https://cvm.tencentcloudapi.com"
ret = requests.get(url, verify="/Test/ssl_address/api.com.crt")
print ret.status_code
解决方法2:
设置环境变量 REQUESTS_CA_BUNDLE:
export REQUESTS_CA_BUNDLE=/tmp/ssl/api.com.crt
然后使用 request 访问。
代码语言:javascript复制#!/bin/env python
import requests
url = "https://cvm.tencentcloudapi.com"
ret = requests.get(url)
print ret.status_code
Scrapy部分
解决方法:
代码语言:javascript复制pip uninstall scrapy
pip uninstall pyopenssl
pip install pyopenssl
pip install scrapy