我一直有在那里有些设备将不会收到一个推送通知,从昨天的一个问题。 证书/设备令牌似乎是正确的,因为该装置用来成功地接收推送通知,直到昨天。
在服务器端,没有任何错误或连接拒绝,并推送通知,似乎每一次成功发送。
但尽管如此,也有许多场合的设备无法正常收到推送。
周围的一些信息:
- 我对生产环境这样做。
- 在服务器端没有错误/连接拒绝
- 我送完全相同的JSON每次。
- 我们的设备2还没有收到推送通知所有自昨日起
- 我们的装置1接收以较低的成功率(约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);
日志告诉我,推成功(切割出隐私令牌):
[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)
我该如何解决这个问题?