rtm_connect to slackbot提供SSL证书验证错误

问题描述 投票:5回答:1

我的工作区里有一个slackbot。我正在使用这个python script连接到slackbot并处理它获得的聊天消息。以下行给出了SSL错误:

slack_client.rtm_connect(with_team_state=False)

错误:

Traceback (most recent call last):
  File "/usr/lib/python2.7/site-packages/slackclient/client.py", line 52, in rtm_connect
    self.server.rtm_connect(use_rtm_start=with_team_state, **kwargs)
  File "/usr/lib/python2.7/site-packages/slackclient/server.py", line 147, in rtm_connect
    self.connect_slack_websocket(self.ws_url)
  File "/usr/lib/python2.7/site-packages/slackclient/server.py", line 186, in connect_slack_websocket
    raise SlackConnectionError(message=str(e))
SlackConnectionError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:579)
Connection failed. Exception traceback printed above.

我尝试在python代码中更新REQUESTS_CA_BUNDLE,但没有用。

如何安装并验证证书?另外,如何跳过证书验证?

有关SSL证书使用的任何详细链接,我们表示赞赏。

ssl slack slack-api
1个回答
3
投票

这个失败的原因来自websocket包和它使用的CA包(它不是最新的)。我无法确定实际使用的是哪个CA捆绑包(我试图更新提供的包以及系统安装的OpenSSL捆绑包),但它可以在命令行上覆盖。

首先,我已经下载了DigiCert证书:

wget https://www.tbs-certificats.com/issuerdata/DigiCertGlobalRootCA.crt

(注意:我在DigiCert页面上找不到官方下载链接,不知道他们为什么不提供它)

然后设置环境变量:

export WEBSOCKET_CLIENT_CA_BUNDLE=DigiCertGlobalRootCA.crt

这对我有用:

$ python bot.py
Starter Bot connected and running!
© www.soinside.com 2019 - 2024. All rights reserved.