解决 requests 库中 verify 属性问题的方法
  MVExqyHJxK4h 2023年11月22日 17 0

解决 requests 库中  verify 属性问题的方法_Python

在使用 Python 的 requests 库进行网络请求时,我们常常需要确保通信的安全性,这涉及到验证服务器的 SSL/TLS 证书。

这个问题的背后是 requests 库的设计,为了解决这个问题,我们可以考虑修改 requests 库的源代码,以确保 verify 参数的优先级高于 REQUESTS_CA_BUNDLE 环境变量。

解决这个问题的方法是修改 requests 库的源代码。

以下是具体的步骤:

  1. 找到 Python 安装目录下的 requests 库源代码文件,通常位于 Lib/site-packages/requests 目录中。
  2. 打开 sessions.py 文件,这是 requests 库的一个关键文件。
  3. sessions.py 文件中找到 Session 类的 request 方法,这个方法用于发送 HTTP 请求。
  4. request 方法中找到如下代码块:
if not verify and self.verify:
    verify = self.verify

这段代码用于检查 verify 参数是否为空,如果为空且 self.verify 不为空,就将 self.verify 的值赋给 verify

  1. 在上述代码块之后,添加以下代码,将 REQUESTS_CA_BUNDLE 环境变量的检查加入其中:
if not verify:
    verify = os.environ.get('REQUESTS_CA_BUNDLE')

这段代码会检查是否存在 REQUESTS_CA_BUNDLE 环境变量,如果存在且 verify 为空,就将其值赋给 verify

  1. 最后,确保 verify 参数被正确传递给底层 HTTP 请求库(通常是 urllib3)。

通过以上步骤,我们成功地修改了 requests 库的源代码,确保 verify 参数的优先级高于 REQUESTS_CA_BUNDLE 环境变量,从而解决了这个问题。

此外,为了避免由于 CA 证书问题导致的错误,我们还可以使用 requests.packages.urllib3.disable_warnings() 来忽略 urllib3 库中的警告信息。 总的来说,解决这个问题需要对 requests 库的源代码有一定的理解,并且需要谨慎地根据实际情况进行适当的修改。在修改前,请务必备份原来的代码,以防出现问题。

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月22日 0

暂无评论

推荐阅读
MVExqyHJxK4h
最新推荐 更多