在 MySQL 数据库中发生更新后立即向 android 发送通知
Posted
技术标签:
【中文标题】在 MySQL 数据库中发生更新后立即向 android 发送通知【英文标题】:send notification to android as soon as update take place in MySQL database 【发布时间】:2017-03-04 11:35:59 【问题描述】:在我的 android 应用程序中,一个新用户最初在应用程序中注册了自己,然后如果用户从后端得到管理员的批准,那么只有他才能登录。现在,我想要的是管理员批准用户,android 手机中应该会出现一条通知,告诉用户现在他可以成功登录,因为他已获得批准。我已将我的数据存储在 web 服务器的 mysql 数据库中。现在我不知道如何实现这一点。任何帮助真的会不胜感激。
【问题讨论】:
你为你尝试了什么? ***.com/questions/25859898/… 我不知道如何实现它。 【参考方案1】:当用户在系统中注册时,您应该存储用户的设备令牌。 当管理员从后端激活用户时,您应该必须通过设备令牌上的 FCM 服务向用户发送通知。
如果您对 FCM 不了解,请访问:https://firebase.google.com/docs/cloud-messaging/concept-options
请在下面找到来自 php 的推送通知发送代码。
function sendFCMPushnotification($arr)
$device_token = $arr['device_token'];
$message = $arr['message'];
$url = 'https://fcm.googleapis.com/fcm/send';
$fields = array (
'registration_ids' => array (
$device_token
),
'data' => array (
"message" => $message,
"sound" => "default"
),
'notification' => array(
'body' => $message,
'title' => 'ProjectName',
)
);
$fields = json_encode ( $fields );
$headers = array (
'Authorization: key=' . "PUT_YOUR_FCM_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_POSTFIELDS, $fields );
$result = curl_exec ( $ch );
var_dump($result);
curl_close ( $ch );
$arr = [
'device_token' => "PLACE_YOUR_DEVICE_TOKEN",
'message' => 'PLACE_YOUR_MESSAGE',
];
sendFCMPushnotification($arr);
【讨论】:
【参考方案2】:首先在您的应用程序中集成推送通知服务。 然后从服务器端,您需要在您批准凭据时发送推送通知,以便用户在应用程序上收到推送通知。
【讨论】:
以上是关于在 MySQL 数据库中发生更新后立即向 android 发送通知的主要内容,如果未能解决你的问题,请参考以下文章