python3.7使用的人多吗_我为什么不建议你使用Python3.7.3?

作者:

Lateautumn4lin

来源:

云爬虫技术研究笔记

之前使用Python的环境一直是

Python3.7.3的,一直使用的很正常,没有什么毛病,直到最近做一个图片下载器的时候发现了问题。

问题如下

这个问题在Python中比较常见,说明是本地的

SSL验证出现了问题,一般在

Requests的使用中我们一般会这么进行处理:

>>> import requests>>> session = requests.Session()>>> session.get('https://wrong.host.badssl.com/', verify=False)/usr/local/lib/python3.7/site-packages/urllib3/connectionpool.py:857: InsecureRequestWarning: Unverified HTTPS request is being made. Adding certificate verification is strongly advised. See: https://urllib3.readthedocs.io/en/latest/advanced-usage.html#ssl-warningsInsecureRequestWarning)>>> session.get('https://wrong.host.badssl.com/', verify=True)/usr/local/lib/python3.7/site-packages/urllib3/connectionpool.py:857: InsecureRequestWarning: Unverified HTTPS request is being made. Adding certificate verification is strongly advised. See: https://urllib3.readthedocs.io/en/latest/advanced-usage.html#ssl-warningsInsecureRequestWarning)

这样就避免了我们使用

https的去验证

SSL证书,不过我这里的问题是使用的是

Aiohttp库,并没有

Verify这个参数,所以我们并不能使用这个去忽略这个问题。

解决一下

Goole了一下,发现其实不止我一个人出现了这个问题,已经有老哥在Aiohttp的Issue里面提了相关的问题了,可以参考https://github.com/aio-libs/aiohttp/issues/3912。

我们可以看出,其实这个BUG并不是Aiohttp的BUG,是Asyncio的BUG,由于Aiohttp底层依赖于Asyncio,所以导致Aiohttp也有相关的问题。不过这个问题已经在Python3.7.4和3.8版本解决了。

可惜我的环境之前是3.7.3

我们知道了问题的解决办法,我们再去看看为什么会有这个问题?

我们先看看

stackoverflow里面的回答

https://stackoverflow.com/questions/52012488/ssl-asyncio-traceback-even-when-error-is-handled

大致意思就是说Asyncio在底层处理SSL握手协议出错的时候,对于错误捕获出现了问题,导致没有准确捕获到错误,进而导致出错。

我们看看官方在fixBug的时候的解决方案

把关于OSError的错误完全捕获住,避免造成错误的遗漏。

最后的小建议

最后建议大家能够使用

3.7.4的时候尽量不使用

3.7.3版本,虽然

3.8也可以避免这个问题,但是

3.8还是刚推出,

BUG问题还是很多的,所以目前这个阶段大家还是尽量使用

3.7.4。

大家要是有什么关于

Python这两个版本的疑问可以尽情提出来!

号主介绍

前两年在二线大厂工作,目前在创业公司搬砖

接触方向是爬虫和云原生架构方面

有丰富的反爬攻克经验以及云原生二次开发经验

其他诸如数据分析、黑客增长也有所涉猎

做过百余人的商业分享以及多次开办培训课程

目前也是CSDN博客专家和华为云享专家

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值