在macOS上将TLS 1.0升级到TLS 1.2

Luc*_*s03 5 python macos openssl tls1.2

我安装某些python软件包时遇到了麻烦,因为我有TLS 1.0版本。如何升级到TLS 1.2?

python -c "import urllib2; import json; print(json.loads(urllib2.urlopen('https://www.howsmyssl.com/a/check').read())['tls_version'])"
TLS 1.0
Run Code Online (Sandbox Code Playgroud)

我的macOS版本:10.13.4(17E202)
python版本:Python 2.7.13
openssl版本:LibreSSL 2.2.7

我试图升级openssl,但它没有升级LibreSSL。我记得一年前我遇到了一些与openssl的问题,我可能已经手动将其链接了,或者::(

Luc*_*s03 3

尽管brew下载了新版本的openssl,但旧版本仍与command一起使用openssl。所以我禁用了 csrutil以摆脱 openssl 符号链接/usr/bin/openssl

sudo ln -s /usr/local/Cellar/openssl/1.0.2o_1/bin/openssl /usr/bin/openssl
Run Code Online (Sandbox Code Playgroud)

那么 openssl 版本是最新的:

~ openssl version
OpenSSL 1.0.2o  27 Mar 2018
Run Code Online (Sandbox Code Playgroud)

然而python仍然使用旧版本的openssl:

~ python -c "import ssl; print(ssl.OPENSSL_VERSION)"
OpenSSL 0.9.8zh 14 Jan 2016
Run Code Online (Sandbox Code Playgroud)

因此,将再次禁用 csrutil 并继续修复 python 版本。

我删除了我能找到的 python2 安装,或多或少如下:

brew uninstall python@2
sudo rm -rf /Library/Frameworks/Python.framework/Versions/2.7
sudo rm -rf "/Applications/Python 2.7"
cd /usr/local/bin/
ls -l /usr/local/bin | grep '../Library/Frameworks/Python.framework/Versions/2.7' | awk '{print $9}' | tr -d @ | xargs rm
Run Code Online (Sandbox Code Playgroud)

然后我通过brew安装了python2,它使用了正确的openssl:

~ brew install python@2
~ python -c "import urllib2,json; print(json.loads(urllib2.urlopen('https://www.howsmyssl.com/a/check').read())['tls_version'])"
TLS 1.2
Run Code Online (Sandbox Code Playgroud)