一次性发送Android推送通知而不是逐个发送

时间:2015-05-10 20:44:47

标签: android push-notification google-cloud-messaging push

我正在尝试向GCM ID存储在MySQL数据库中的用户发送推送通知。 问题在于我的代码,我正在获取ID并在while循环中逐个发送它们。如果用户数量很大,那就是有很多ID(大约700个)服务器正在给出一个内部错误...而一旦我减少数量(大约200),代码运行正常,我没有得到任何错误。

我的问题是,有没有办法一次性发送推送通知而不是一个一个。

以下是我使用发送的代码。

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 );

2 个答案:

答案 0 :(得分:1)

GCM HTTP Connection Server - Source

将数据库中的注册ID作为数组检索,并使用每个注册表填充$registatoin_ids数组,并将其发送一次。

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

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

    }

答案 1 :(得分:1)

是的,您可以一次性向多达1000台设备发送通知。您可以一次创建一个包含1000个注册ID的数组,并将其放在请求的registration_ids值中。

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

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