iOS推送通知连接失败错误

时间:2013-08-30 09:20:27

标签: ios push-notification apple-push-notifications telnet

我正在尝试通过php在iOS应用程序中发送推送通知。所以iOS开发人员给我pem文件。我请求托管服务器打开gateway.sandbox.push.apple.com:2195并打开端口。但是当我尝试发送推送通知时,我收到以下错误。我的代码看起来像

$deviceToken='XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX';

$passphrase="";

$ctx = stream_context_create();
stream_context_set_option($ctx, 'ssl', 'local_cert', '/home/sitename/public_html/push/ck.pem');
stream_context_set_option($ctx, 'ssl', 'passphrase', $passphrase);

$fp = stream_socket_client('ssl://gateway.sandbox.push.apple.com:2195', 
    $err, 
    $errstr, 
    60, 
    STREAM_CLIENT_CONNECT|STREAM_CLIENT_PERSISTENT, 
    $ctx);

if (!$fp)
exit("Failed to connect amarnew: $err $errstr" . PHP_EOL);

echo 'Connected to APNS' . PHP_EOL;

获得以下错误

Failed to connect amarnew: 0 

所以我尝试通过telnet连接到apple,结果是

root@uio3-i [~]# telnet gateway.sandbox.push.apple.com 2195
Trying XX.XXX.XXX.XX...
Connected to gateway.sandbox.push.apple.com.
Escape character is '^]'.
^\q
^]
telnet> q
Connection closed.
root@uio3-i [~]#

由于我是新手,我只是坚持到这里。请任何人帮助我

提前致谢

1 个答案:

答案 0 :(得分:5)

听起来像你的证书/密钥对.pem文件已损坏,重新生成它。我只是自己推动工作,所以我知道这是一个棘手的话题。

而不是简单地telnet(只证明连接是正常的),而是从终端运行此命令以确定Cert和Key是否有效。

openssl s_client -connect gateway.sandbox.push.apple.com:2195 
-cert cert.pem -key key.pem

你应该看到一大堆输出,这是openssl让你知道幕后发生了什么。

如果连接成功,您应该能够键入几个字符。按Enter键时,服务器应断开连接。如果建立连接时出现问题,openssl会给出错误消息,但您可能需要向上滚动输出才能找到它。

无论哪种方式,至少你会知道你的证书/密钥对是否良好。

在生产中,您必须使用连接的证书/密钥对 - 如果您没有原始密钥和证书,则需要从开发人员那里获取以测试上述内容。