在数据库MySql中的所有令牌上发送推送通知

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在数据库MySql中的所有令牌上发送推送通知相关的知识,希望对你有一定的参考价值。

我已经为我的应用创建了推送通知,它工作正常,但没有在所有设备令牌上发送通知。

首先我有一个数据库名称“member”,它包含id,username,password,token

然后我创建这个php函数来发送通知

<?php
// API access key from Google API's Console
define( 'API_ACCESS_KEY', 'XXXXXXXXXXXXXXXXX' );
include 'DatabaseConfig.php';

 $con = mysqli_connect($HostName,$HostUser,$HostPass,$DatabaseName);
$checktoken = "SELECT token FROM member";
$results = $con->query($checktoken);

if ($results ->num_rows > 0) {

while($row = $results->fetch_assoc()){

$regid = array($row["token"]);
echo "" .$row["token"]. " ";
}
}else{
echo "No result";
}

// prep the bundle
$msg = array
(
    'body'  => 'here is a message. message',
    'title'     => 'This is a title. title',
    'subtitle'  => 'This is a subtitle. subtitle',
    'tickerText'    => 'Ticker text here...Ticker text here...Ticker text here',
    'vibrate'   => 1,
    'sound'     => 'mySound',
    'largeIcon' => 'large_icon',
    'smallIcon' => 'small_icon'
);
$fields = array
(
    'registration_ids'  => $regid,
    'notification'          => $msg
);

$headers = array
(
    'Authorization: key=' . API_ACCESS_KEY,
    'Content-Type: application/json'
);

$ch = curl_init();
curl_setopt( $ch,CURLOPT_URL, 'https://android.googleapis.com/gcm/send' );
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 );
echo $result;

代码只发送到一个设备,当我尝试在浏览器中访问它时显示

eY0-0uIUDsA:APA91bGmFatL_gtizFRbC9mMbagzsMalJuJ6e_O2poytaKgBTVIsyl5ogJ4-x7PlQebyu6z7ME970H9hdlZUEiLESTNPrSvcn_1PzmKh3AJiwIUZj86_fRxPt9yOpL4k3PZb7Ir6xf43 dPEPzRFjnIo:APA91bHBaHO8nZK2g4xF6vzvKrevNhpBRSdIb3NyWrr2PRCEyDR9cLkCZOZ28_hu5pDzdaSKkRxPY1mvYO8ZOnjEscjdKGCEv-FIdIBzrz32mof0rQSlog028kDhv7jltGjWwK7r7l-J { “multicast_id”:9198379759567809790, “成功”:1, “失败”:0, “canonical_ids”:0 “结果”:[{ “MESSAGE_ID”:” 0:1513945312938936%cd487dfdcd487dfd“}]}

它有2个设备,但为什么它只发送到一个设备令牌?我的代码的任何修复?

为您的信息第一个设备以eY0-0uIUDsA开头:第二个以dPEPzRFjnIo开头:

答案

你在每次循环迭代时都要覆盖$ regid的内容。在循环外定义数组:

$regid = [];

if ($results ->num_rows > 0) {
    while($row = $results->fetch_assoc()){
        $regid[] = $row["token"];
        echo "" .$row["token"]. " ";
     }
 } else {
     echo "No result";
 }

另外,最好带上在if的正分支内发送通知的代码,只有在得到结果时才需要发送。

以上是关于在数据库MySql中的所有令牌上发送推送通知的主要内容,如果未能解决你的问题,请参考以下文章

从服务器向所有设备发送推送通知

推送通知令牌在单个设备的所有应用程序中是不是唯一?

APNS:无效令牌导致所有后续推送通知失败

如何在 iPhone 上指定推送通知的用户?

使用 AWS SNS 向特定 APNS 令牌发送推送通知

Firebase 云功能不发送异步推送通知