栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

解决python使用猴子补丁时引入ssl错误

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

解决python使用猴子补丁时引入ssl错误

    首先是requests对https发起请求时报ssl错误
    解决: requests提供了两个参数 1. verify 官方给出的解释为 当参数为False时,请求将接受由提交的任何TLS证书并将忽略主机名不匹配和/或过期证书,这将使您的应用程序容易受到攻击 2. cert 接收一个元组类型即(“cret”,key) 如果是字符串,那么就要传输一个ssl证书路径

    所以只需要在发起请求时,加入verify=False
d = requests.get(
    "https://host:port/atps/testCaseTask/webDriverTask?scheduleTaskId=3&testCaseTaskId=5", verify=False)
print(d)
    当然 如果你不得不用到协程gevent并给他打上了猴子补丁,且引入了ssl(如果使用了verify的话)并且报出了一个异常:RecursionError: maximum recursion depth exceeded while calling a Python object
    那么我猜你的代码有可能是这样写的
import requests
from gevent import monkey
monkey.patch_all()
d = requests.get(
    "https://host:port/atps/testCaseTask/webDriverTask?scheduleTaskId=3&testCaseTaskId=5", verify=False)
print(d)

并且刚刚会报出一个异常:MonkeyPatchWarning: Monkey-patching ssl after ssl has already been imported may lead to errors, including RecursionError on Python 3.6. It may also silently lead to incorrect behaviour on Python 3.7. Please monkey-patch earlier. See https://github.com/gevent/gevent/issues/1016. Modules that had direct imports (NOT patched): [‘urllib3.util.ssl_ (D:pythonlibsite-packagesurllib3utilssl_.py)’, ‘urllib3.util (D:pythonlibsite-packagesurllib3utilinit.py)’].
monkey.patch_all()
这个异常告诉你, 你应该去把这个引入放到最前面去执行,因为他会更改ssl的代码
如果真的是这样的话,那么我建议你将
from gevent import monkey
monkey.patch_all()
这两行代码放到最顶部去 其原因就是让猴子补丁尽早的生效

感谢各位观看,如有其他问题可以私信我 让我们共同进步

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/769080.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号