我正在尝试使用连接到的简单 PHP 工具向我的手机发送推送通知ssl://gateway.push.apple.com:2195
,但连接失败并出现以下错误:
Warning: stream_socket_client(): SSL operation failed with code 1. OpenSSL Error messages:
error:14090086:SSL routines:SSL3_GET_SERVER_CERTIFICATE:certificate verify failed in <Users/.../file.php> on line 30
Warning: stream_socket_client(): Failed to enable crypto in <Users/.../file.php> on line 30
Warning: stream_socket_client(): unable to connect to ssl://gateway.sandbox.push.apple.com:2195 (Unknown error) in <Users/.../file.php> on line 30
Failed to connect: 0
这一切都是从我升级到 macOS Sierra 的 GM Seed 开始的。
macOS Sierra 中有哪些新功能会影响 SSL 连接?
我该如何解决这个问题?
我遇到了同样的错误,这就是我所做的:
1)更新了我的openssl(我想你不需要这个)进入第2步,因为这将需要大约10分钟
brew install openssl
确保您更新正确:
openssl version
如果没有,请尝试这个或谷歌:
brew link --force openssl
2)检查 php default_cert_file 路径:
php -r "print_r(openssl_get_cert_locations());"
这就是我得到的:
Array
(
[default_cert_file] => /usr/local/libressl/etc/ssl/cert.pem
[default_cert_file_env] => SSL_CERT_FILE
[default_cert_dir] => /usr/local/libressl/etc/ssl/certs
[default_cert_dir_env] => SSL_CERT_DIR
[default_private_dir] => /usr/local/libressl/etc/ssl/private
[default_default_cert_area] => /usr/local/libressl/etc/ssl
[ini_cafile] =>
[ini_capath] =>
)
3)从这里下载cacert.pem:
wget http://curl.haxx.se/ca/cacert.pem
4) 将 cacert.pem 文件移动到 default_cert_file 路径(以 root 身份):
sudo mv cacert.pem /usr/local/libressl/etc/ssl/cert.pem
可能我需要先创建这个目录
之后,我的 php 脚本就工作了。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)