关于Python3中请求报错:ssl:certificate_verify_failed

在编写公司接口测试的时候,requests.get()方法请求时遇到certificate_verify_failed的问题,如下图

图片:如上图,ssl报错

SSL:ssl:certificate_verify_failed错误,是指连接HTTPS时的ssl证书鉴证失败,在Python2.8及3上都会出现,解决办法如下:

  1. 有查到两种解决办法:

    1. 全局取消ssl证书验证,代码如下:
import ssl
		
ssl._create_default_https_context = ssl._create_unverified_context()
  • but,这种方法,我试了一下貌似没起效,有点摸不着头脑,另外这种方法稍微有些不太安全
  1. 局部取消ssl证书验证,有两种小情况:
    第一种:是用urlopen()方法请求时使用的:
import ssl
# 使用ssl创建未验证的上下文,在url中传入上下文参数
context = ssl._create_unverified_context()
# 将context传入url函数的context参数中,比如
urllib2.urlopen('目标网址',context=context).read()
  • 此方法亲测可用,
    但是我在进行requests.get()请求,所以,这种不太符合我的需求,就又翻找了一下,终于找到了下边这种方法

     第二种:在requests的get/post方法中都有verify这个参数,表示是否验证
    
r = requests.get("xxx.com", headers=request_headers, verify=False)
print r.content
  • 亲测可用,会报一个warning报警,但是不影响使用,报警如下:

报警如图

  • 到此处certificate_verify_failed 问题已解决。

赠送:requests请求中verify=False时的InsecureRequestWarning问题

最后的warning问题,每次都出现也很不舒服,也可以干掉它,如下

# 禁用requests出现的取消ssl验证的警告,直接引用如下
from requests.packages.urllib3.exceptions import InsecureRequestWarning
requests.packages.urllib3.disable_warnings(InsecureRequestWarning)

然后run一下,你会发现,不再报警了,棒棒!!!

———————————————————————————————————————————————————————————

引用连接:

https://blog.csdn.net/yixieling4397/article/details/79861379
https://blog.csdn.net/u012478031/article/details/60578318?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.nonecase&depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.nonecase

  • 15
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
引用提到的错误提示"ssl.SSLCertVerificationError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: unable to get local issuer certificate (_ssl.c:1076)"通常是由于SSL证书验证问题引起的。这个错误意味着SSL证书验证失败,无法获取本地颁发机构证书。可能的原因是缺少或不正确的证书。为了解决这个问题,可以尝试以下几种方法。 首先,根据引用的解决办法,如果没有明确的HTTP地址,可以尝试全局取消证书验证。这可以通过添加以下两行代码实现: ```python import ssl ssl._create_default_https_context = ssl._create_unverified_context ``` 这将创建一个未经验证的SSL上下文,从而绕过证书验证。但请注意,这可能会降低安全性,因此请谨慎使用。 另外,引用提到,可以查阅资料并找到正确的SSL证书来解决该问题。您可以尝试获取并安装正确的本地颁发机构证书,以便正确进行SSL证书验证。您可以从证书颁发机构或相关网站获取证书,并按照相应的指导进行安装。 如果以上方法仍然无法解决问题,您还可以尝试更新PythonSSL证书库。您可以通过更新Python的版本或重新安装Python来获取最新的SSL证书库。 总之,当遇到"SSLCertVerificationError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: unable to get local issuer certificate (_ssl.c:1131)"错误时,可以尝试全局取消证书验证或安装正确的SSL证书来解决问题。如果问题仍然存在,可以考虑更新PythonSSL证书库。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [ssl.SSLCertVerificationError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: unable to](https://blog.csdn.net/zhouchuanlun/article/details/107861883)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [错误【ssl.SSLCertVerificationError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed...】](https://blog.csdn.net/qq_36717487/article/details/127456007)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值