2015-05-10 65 views
0

我試圖發送推送通知給GCM ID存儲在MySQL數據庫中的用戶。 事情是與我的代碼,我獲取ID並在一個while循環內一個接一個地發送它們。如果用戶數量很大,那就是有很多ID(大約700),服務器給出了一個內部錯誤...而一旦我減少了數量(大約200),代碼運行良好,我沒有得到任何錯誤。發送Android推送通知一次而不是一個一個

我的問題是,有沒有辦法將推送通知發送一次而不是逐個發送。

下面是我使用send的代碼。

include(「/home/myHome/db/db.php」);

$resultTokenUser = $mysqli->query ('select * from android'); 

if ($resultTokenUser->num_rows > 0) 
{    
    while ($row = $resultTokenUser->fetch_assoc()) 
    {   
     $token = $row ['gcm_regid']; 
     $registatoin_ids = array ("$token"); 

     $messageToSend = array (
       "notificationMessage" => "Hello", 
     ); 

     $url = 'https://android.googleapis.com/gcm/send'; 

     $fields = array (
       'registration_ids' => $registatoin_ids, 
       'data' => $messageToSend 
     ); 

     define ("GOOGLE_API_KEY", "myKey"); 
     $headers = array (
       'Authorization: key=' . GOOGLE_API_KEY, 
       'Content-Type: application/json' 
     ); 
     $ch = curl_init(); 
     curl_setopt ($ch, CURLOPT_URL, $url); 
     curl_setopt ($ch, CURLOPT_POST, true); 
     curl_setopt ($ch, CURLOPT_HTTPHEADER, $headers); 
     curl_setopt ($ch, CURLOPT_RETURNTRANSFER, true); 
     curl_setopt ($ch, CURLOPT_SSL_VERIFYPEER, false); 
     curl_setopt ($ch, CURLOPT_POSTFIELDS, json_encode ($fields)); 
     $result = curl_exec ($ch); 
    } 
} 

curl_close ($ch); 

回答

1

GCM HTTP Connection Server - Source

從DB作爲數組獲取的註冊ID,並填寫$registatoin_ids陣列,每個REG ID,只是一次發送。

$registatoin_ids = array(); 
    for($i=0;$i<$reg_id_count;$i++) { 

     array_push($registatoin_ids, $row[$i]['gcm_regid']); 

    } 
1

是的,您可以一次發送通知到多達1000個設備。您可以一次創建1000個註冊ID的數組,並將其放入請求的registration_ids值中。

$registration_ids=array("id1", "id2",…...." Id1000"); 

$fields = array(
    'registration_ids' => $registatoin_ids, 
    'data' => $message, 
); 
相關問題