ios – APNs通过macOS Sierra推送通知

前端之家收集整理的这篇文章主要介绍了ios – APNs通过macOS Sierra推送通知前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试使用连接到ssl://gateway.push.apple.com:2195的简单 PHP工具发送手机推送通知,但连接失败并显示以下错误
  1. Warning: stream_socket_client(): SSL operation Failed with code 1. OpenSSL Error messages:
  2. error:14090086:SSL routines:SSL3_GET_SERVER_CERTIFICATE:certificate verify Failed in <Users/.../file.PHP> on line 30
  3.  
  4. Warning: stream_socket_client(): Failed to enable crypto in <Users/.../file.PHP> on line 30
  5.  
  6. Warning: stream_socket_client(): unable to connect to ssl://gateway.sandBox.push.apple.com:2195 (Unknown error) in <Users/.../file.PHP> on line 30
  7. Failed to connect: 0

这一切都是从我升级到GMOS Sierra的GM Seed开始的.
macOS Sierra的新增功能会影响SSL连接?
我该如何解决

解决方法

我有同样的错误,这就是我所做的:

1)更新我的openssl(我认为你不需要这个)得到第2步,因为这将需要大约10分钟

  1. brew install openssl

确保你更新它是正确的:

  1. openssl version

如果没有,请尝试此或谷歌:

  1. brew link --force openssl

2)检查你的PHP default_cert_file路径:

  1. PHP -r "print_r(openssl_get_cert_locations());"

这是我得到的:

  1. Array
  2. (
  3. [default_cert_file] => /usr/local/libressl/etc/ssl/cert.pem
  4. [default_cert_file_env] => SSL_CERT_FILE
  5. [default_cert_dir] => /usr/local/libressl/etc/ssl/certs
  6. [default_cert_dir_env] => SSL_CERT_DIR
  7. [default_private_dir] => /usr/local/libressl/etc/ssl/private
  8. [default_default_cert_area] => /usr/local/libressl/etc/ssl
  9. [ini_cafile] =>
  10. [ini_capath] =>
  11. )

3)从这里下载cacert.pem:

  1. wget http://curl.haxx.se/ca/cacert.pem

4)将cacert.pem文件移动到您的default_cert_file路径(以root用户身份):

  1. sudo mv cacert.pem /usr/local/libressl/etc/ssl/cert.pem

可能我需要先创建这个目录

之后,我的PHP脚本工作.

猜你在找的iOS相关文章