最近出现了一些设备无法接收推送通知的问题,从昨天开始。证书/设备令牌似乎是正确的,因为这些设备直到昨天都能成功地接收到推送通知。
在服务器端,没有任何错误或连接拒绝,并且每次推送通知似乎都发送成功了。
但是,仍然有很多情况下设备未能正确地接收到推送通知。
以下是一些相关信息:
- 我正在生产环境中进行此操作。
- 服务器端没有错误/连接拒绝
- 我每次发送完全相同的JSON。
- 昨天起我们有两个设备根本无法接收到推送通知
- 我们的一个设备接收推送通知的成功率比昨天低(约为70%)
- 1〜2个设备仍然成功地接收到推送通知。
- 所有上述设备都能够在生产环境中正确接收推送通知,直到昨天为止。
当推送成功或设备未能接收到推送时,服务器端结果没有任何区别...因此几乎不可能识别问题所在。
这是我使用的服务器端PHP代码:
$ctx = stream_context_create();
stream_context_set_option($ctx, 'ssl', 'local_cert', $this->apnsData[$development]['certificate']);
$fp = stream_socket_client($this->apnsData[$development]['ssl'], $error, $errorString, 100, (STREAM_CLIENT_C ONNECT|STREAM_CLIENT_PERSISTENT), $ctx);
if(!$fp){
$this->_pushFailed($pid);
$this->_triggerError("Failed to connect to APNS: {$error} {$errorString}.");
}
else {
$msg = chr(0).pack("n",32).pack('H*',$token).pack("n",strlen($message)).$message;
$fwrite = fwrite($fp, $msg);
if(!$fwrite) {
error_log("[APNS] push failed...");
$this->_pushFailed($pid);
$this->_triggerError("Failed writing to stream.", E_USER_ERROR);
}
else {
error_log("[APNS] push successful! ::: $token -> $message ($fwrite bytes)");
}
}
fclose($fp);
日志告诉我推送成功了(为保护隐私,已删除token):
[Wed Dec 12 11:42:00 2012] [error] [client 10.161.6.177] [APNS] push successful! ::: aa4f******44 -> {"aps":{"alert":{"body":"\\u300casdfasdf\\u300d","action-loc-key":"OK"},"badge":4,"sound":"chime"}} (134 bytes)
我该如何解决这个问题?