python使用requests时报错requests.exceptions.SSLError: HTTPSConnectionPool
报错信息
data:image/s3,"s3://crabby-images/bfc71/bfc7165cb3c681020af60b7b541dcce5869a7794" alt=""
过程
测试1
不指定headers时GET:
data:image/s3,"s3://crabby-images/a71db/a71dbad8a770d7cd643636a3a0b947a7a8eb68fc" alt=""
data:image/s3,"s3://crabby-images/1e8e8/1e8e8b3027b97bbee0bb322fdeb5ff016a748535" alt=""
测试2
当指定headers的User-Agent为火狐浏览器时:
data:image/s3,"s3://crabby-images/d1457/d145709043ddb2c21d8bb921d74f7121618b3304" alt=""
data:image/s3,"s3://crabby-images/af5cf/af5cf72f6ff1773240977a18f88abc9b21b66a4e" alt=""
分析
现象:第一次GET时正常,第二次GET时,会报错.
不同点:User-Agent不相同
分析:由于报错SSL证书验证失败,所以这次的访问应该是https协议.但是我们明明使用的是http,所以,猜测访问该网站后,被重定向到了https://www.baidu.com/
验证
首先,进行GET时,关闭证书验证.因为,如果不关闭,请求总是失败,不能获取到重定向的信息.
data:image/s3,"s3://crabby-images/92e5b/92e5bc1ca29d96425cf595fa25f53cee9f1915ff" alt=""
data:image/s3,"s3://crabby-images/9a650/9a650837709c37093a637872b8316ba2bade8535" alt=""
当不指定User-Agent时
data:image/s3,"s3://crabby-images/8291a/8291adcb04bdd0335f6a414a9786a3a51b9e354a" alt=""
data:image/s3,"s3://crabby-images/41db9/41db93f5466fc4094d7b7c9a7499dfd21e6044ab" alt=""
结论
当指定headers的User-Agent时,baidu的服务器会重定向到https的网址.因此报出SSL验证失败的错误.
解决方法
方法1:
在进行GET时,指定SSL证书.详情见附件
方法2:
关闭证书验证. 详情见附件
本文来自博客园,作者:I'm_江河湖海,转载请注明原文链接:https://www.cnblogs.com/jhhh/p/16765174.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)