在数据库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中的所有令牌上发送推送通知的主要内容,如果未能解决你的问题,请参考以下文章