当应用程序从最近使用的应用程序

时间:2017-03-09 15:25:03

标签: android firebase push-notification firebase-cloud-messaging

我正在使用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);
}
}

1 个答案:

答案 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