1

我正在尝试访问 at https://www.ncdc.noaa.gov/cdo-we/api/v2/这需要在此处请求时立即收到一个令牌。然后:

import requests


def get_noaa_data(url, data_type, header):

    r = requests.get(url, data_type, headers=header)
    print(r)


if __name__ == '__main__':

    token = 'longalphabetictoken'
    creds = dict(token=token)
    dtype = 'dataset'
    url = 'https://www.ncdc.noaa.gov/cdo-web/api/v2/'

    get_noaa_data(url, dtype, creds)

requests.exceptions.SSLError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:720)

我知道我可以设置verify=False,但我确实想验证。我还希望能够分发此代码,因此我不想通过修改我的 cacert.pem 来解决问题。我也尝试过将其certifi导入脚本。如果人们下载我的包,是否有一种与操作系统无关的方法来验证 NOAA 网站的 SSL 证书?

在我看来,如果没有verify=False. 这是我组织的机器的问题吗?

ssl.get_default_verify_paths() = DefaultVerifyPaths(cafile='/data01/anaconda2/envs/imagenv/ssl/cert.pem', capath=None, openssl_cafile_env='SSL_CERT_FILE', openssl_cafile='/data01/anaconda2/envs/imagenv/ssl/cert.pem', openssl_capath_env='SSL_CERT_DIR', openssl_capath='/data01/anaconda2/envs/imagenv/ssl/certs')

仅供参考:亚马逊、谷歌等 https 网站运行良好。

4

1 回答 1

0

您需要确保您组织的 SSL 证书是由证书颁发机构 (CA) 签署的,否则 ssl 连接将无法正常工作。

于 2017-06-07T21:44:16.580 回答