データベース挿入イベントでPHPスクリプトを使用してFCM通知を送信しようとしましたが、FCMコンソールから送信しようとしましたが、トピックオプションを使用して問題なく動作しました。 MainActivity.java OnCreateイベントクラスに次のコードを使用して "exptopic":次のようにアンドロイドのFCM通知
FirebaseMessaging.getInstance().subscribeToTopic("exptopic");
今PHPスクリプトは次のとおりです。
明らか$target = "exptopic"
、私はsnedMessage機能を実行すると、それは返し
function sendMessage($data,$target){
//FCM api URL
$url = 'https://fcm.googleapis.com/fcm/send';
//api_key available in Firebase console -> project settings -> cloud messaging -> server key
$server_key = "API_KEY";//my api key
$fields = array();
$fields['data'] = array('message'=>$data);
$fields['to'] = $target;
$headers = array('content-type:application/json',
'Authorization:key='.$server_key);
$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_VERIFYHOST, 0);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($fields));
$result = curl_exec($ch);
if($result === FALSE){
die('FCM Send error: '.curl_error($ch));
echo 'notification not sent';
}
curl_close($ch);
echo $result;
return $result;
}
結果:
{"multicast_id":6779996340041741184,"success":0,"failure":1,"canonical_ids":0,"results":[{"error":"InvalidRegistration"}]}
誰でも手助けできますか?
MySQLが削除この質問、タグに関連すると思われないようになります。たぶん、この試みを与えます。 – tadman