从最近使用的应用程序中删除应用程序时,没有在Android移动设备中收到通知



我正在使用firebase云消息传递将通知发送到我的应用程序。我在前景中的应用程序中获取通知,然后切换到另一个应用程序(我的应用程序在后台运行的应用程序未关闭)。但是,当我从最近的二手应用中删除时。我没有收到通知。我也获得了令牌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);
}
}

您要问的是FCM上不支持的(这曾与GCM一起使用,而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允许用户控制此标志 - 但这是由开发团队

击落的

相关内容

最新更新