[英]Why would only some devices be receiving push notifications
我設置了一個推送通知服務,以基於RSS提要向客戶端發送通知。 我有每分鍾運行一次的服務,以查看是否有新帖子添加到了提要中。 如果是這樣,該服務將向所有客戶端發出通知。 但是,有些人一直抱怨說他們沒有收到任何推送通知。 這是我用來發送消息的功能:
function _sendMessages($tokens, $message) {
$payload['aps'] = array('alert' => $message, 'sound' => 'default');
$payload = json_encode($payload);
$context = stream_context_create();
stream_context_set_option($context, 'ssl', 'local_cert', $this->certificate);
stream_context_set_option($context, 'ssl', 'passphrase', '*********');
$apns = stream_socket_client('ssl://' . $this->server . ':' . $this->port, $error, $errorString,60, STREAM_CLIENT_CONNECT, $context);
foreach($tokens as $row) {
$apnsMessage = chr(0) . chr(0) . chr(32) . pack('H*', str_replace(' ', '', $row->device_token)) . chr(0) . chr(strlen($payload)) . $payload;
$fwrite = fwrite($apns, $apnsMessage);
if (!$fwrite) echo 'push error';
else echo 'push success';
}
fclose($apns);
}
我做錯什么了嗎? PHP不能處理數千次遍歷此循環並通過連接流式傳輸消息嗎?
除了其他人已經提出的建議之外,還有一些清單,這些清單在推送無效時要考慮的事項。
希望這可以幫助。
我認為這里存在3個潛在問題:
1)您連接的頻率太高(可能比您想像的要頻繁),而Apple拒絕/斷開連接是因為它認為您太垃圾了。 坦白地說,這將是顯而易見的-由於流已失效,因此您的fwrite將會失敗。
理想情況下,APNS希望連接保持盡可能長的打開時間(10分鍾是我們使用的不活動超時),而不是每分鍾重新建立一次。 SSL協商需要花費CPU,但是保持開放狀態的連接相對便宜。 因此,如果可以的話,我會在運行之間保持該連接的打開狀態,如果由於任何原因將其刪除,則會自動重新建立該連接。
2)您沒有進行任何錯誤檢查。 請參閱《 APNS指南》,但它可能會通過錯誤響應沿着相同的連接進行響應,而您只是忽略了這一點。 我認為,每次循環時,您都應該檢查是否有任何數據要讀取,讀取並將其解釋為錯誤響應數據包。 至少您應該注銷錯誤響應。
3)這是一個遠射。 您是否真的可能刪除了這些用戶,也許是因為反饋服務告訴您? 如果用戶長時間斷開連接,則該服務將無法發送通知,並且該通知可能會告訴您從列表中刪除這些設備。 如果您在應用啟動時不重新訂閱這些用戶(或至少確認他們仍在訂閱),那么實際上您已經選擇忘記他們時,他們會認為他們已訂閱了通知。
嗯...我沒有發現任何問題。 客戶實際上是否為您的應用程序啟用了推送通知?
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.