我正在使用firebase云消息传递给我的应用程序发送通知。当我的应用程序在前台时我收到通知,并切换到另一个应用程序(我的应用程序在后台运行未关闭)。 但是,当我从最近使用过的app中删除时,我没有得到通知。 我也得到了令牌ID。当应用程序从最新使用的应用程序中删除时,问题是没有收到通知。
Android清单文件: 内幕申请
<service
android:name="com.mysite.android.abc.service.MyFirebaseMessagingService"
android:permission="android.permission.RECEIVE_BOOT_COMPLETED"
>
<intent-filter>
<action android:name="com.google.firebase.MESSAGING_EVENT"/>
</intent-filter>
</service>
<!-- [END firebase_service] -->
<!-- [START firebase_iid_service] -->
<service
android:name="com.mysite.android.abc.service.MyFirebaseInstanceIDService"
>
<intent-filter>
<action android:name="com.google.firebase.INSTANCE_ID_EVENT"/>
</intent-filter>
</service>
<!-- [END firebase_iid_service] -->
<receiver
android:name=".service.FirebaseDataReceiver"
android:exported="true"
android:permission="com.google.android.c2dm.permission.SEND">
<intent-filter>
<action android:name="com.google.android.c2dm.intent.RECEIVE" />
</intent-filter>
</receiver>
MyFirebaseInstanceIDService:
public class MyFirebaseInstanceIDService extends FirebaseInstanceIdService {
@Override
public void onTokenRefresh() {
super.onTokenRefresh();
String refreshedToken = FirebaseInstanceId.getInstance().getToken();
// Notify UI that registration has completed, so the progress indicator can be hidden.
Intent registrationComplete = new Intent( Config.REGISTRATION_COMPLETE);
registrationComplete.putExtra("token", refreshedToken);
LocalBroadcastManager.getInstance(this).sendBroadcast(registrationComplete);
}
}
MyFirebaseMessagingService:
public class MyFirebaseMessagingService extends FirebaseMessagingService {
private NotificationUtils notificationUtils;
@Override
public void onMessageReceived(RemoteMessage remoteMessage) {
super.onMessageReceived( remoteMessage );
if(remoteMessage==null){
return;
}
if (remoteMessage.getNotification()!=null) {
handleNotification( remoteMessage.getNotification().getBody() );
}
if(remoteMessage.getData().size()>0){
try {
JSONObject jsonObject=new JSONObject( remoteMessage.getData().toString() );
handleDataMessage( jsonObject );
}catch (Exception e){
e.printStackTrace();
}
}
}
private void handleNotification(String message){
if(!NotificationUtils.isAppIsInBackground( getApplicationContext() )){
Intent pushNotification=new Intent( Config.PUSH_NOTIFICATION );
pushNotification.putExtra( "message",message );
LocalBroadcastManager.getInstance( this ).sendBroadcast( pushNotification );
// play notification sound
/*NotificationUtils notificationUtils = new NotificationUtils(getApplicationContext());
notificationUtils.playNotificationSound();*/
}else{
}
}
private void handleDataMessage(JSONObject jsonObject){
Log.e("GGGGG mm",jsonObject.toString());
try {
JSONObject data=jsonObject.getJSONObject( "data" );
String title=data.getString( "title" );
String message=data.getString( "message" );
JSONObject payload = data.getJSONObject("payload");
if(!NotificationUtils.isAppIsInBackground( getApplicationContext() )){
// app is in foreground, broadcast the push message
Intent pushNotification = new Intent(Config.PUSH_NOTIFICATION);
pushNotification.putExtra("message", message);
LocalBroadcastManager.getInstance(this).sendBroadcast(pushNotification);
// play notification sound
/*NotificationUtils notificationUtils = new NotificationUtils(getApplicationContext());
notificationUtils.playNotificationSound();*/
} else {
// app is in background, show the notification in notification tray
Intent resultIntent = new Intent(getApplicationContext(), Dashboard.class);
resultIntent.putExtra("message", message);
// check for image attachment
if (TextUtils.isEmpty(imageUrl)) {
showNotificationMessage(getApplicationContext(), title, message, timestamp, resultIntent);
} else {
// image is present, show notification with image
showNotificationMessageWithBigImage(getApplicationContext(), title, message, timestamp, resultIntent, imageUrl);
}
}
} catch (JSONException e) {
e.printStackTrace();
}
}
/**
* Showing notification with text only
*/
private void showNotificationMessage(Context context, String title, String message, String timeStamp, Intent intent) {
notificationUtils = new NotificationUtils(context);
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TASK | Intent.FLAG_INCLUDE_STOPPED_PACKAGES);
notificationUtils.showNotificationMessage(title, message, timeStamp, intent);
}
/**
* Showing notification with text and image
*/
private void showNotificationMessageWithBigImage(Context context, String title, String message, String timeStamp, Intent intent, String imageUrl) {
notificationUtils = new NotificationUtils(context);
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TASK | Intent.FLAG_INCLUDE_STOPPED_PACKAGES);
notificationUtils.showNotificationMessage(title, message, timeStamp, intent, imageUrl);
}
}
答案 0 :(得分:1)
FCM不支持您要问的内容(该功能以前已与GCM一起使用,现已弃用)
https://developer.android.com/about/versions/android-3.1#launchcontrols:
请注意,系统将FLAG_EXCLUDE_STOPPED_PACKAGES添加到所有 广播意图。这样做是为了防止背景广播 来自无意或不必要地启动组件的服务 停工的应用程序。后台服务或应用程序可以 通过添加FLAG_INCLUDE_STOPPED_PACKAGES来覆盖此行为 标记以广播应允许激活的意图 应用程序。
应用程序在首次安装时处于停止状态,但是 还没有启动,以及由用户手动停止时 (在“管理应用程序”中)。
广播FCM触发器将FLAG_EXCLUDE_STOPPED_PACKAGES设置为TRUE,如果用户强行停止了应用程序,则它实际上不会唤醒您的应用程序(与您一样)。
有人要求Firebase允许用户控制此标志-但这是开发团队shot down的