2016-09-14 35 views
16

我从Android Studio的Android监视器收到该错误。当我通过GCM发送推送通知,在真实设备中,并且应用尚未启动或被迫停止时,会出现此错误。昨天一切正常,今天根本不工作(只有当应用程序在后台或前台运行时才有效)。错误广播意图回调:结果= CANCELED forIntent {act = com.google.android.c2dm.intent.RECEIVE pkg = com.flagg327.guicomaipu(有额外)}

我认为这可能是一个AndroidManifest错误,但我厌倦了寻找问题,找不到任何东西。

清单

<manifest 
    xmlns:android="http://schemas.android.com/apk/res/android" 
    package="com.flagg327.guicomaipu"> 

    ... 

    <application 
     android:allowBackup="true" 
     android:icon="@mipmap/ic_launcher" 
     android:label="@string/app_name" 
     android:supportsRtl="true" 
     android:theme="@style/AppTheme"> 

     ... 

     <!--GOOGLE CLOUD MESSAGE--> 
     <receiver 
      android:name="com.google.android.gms.gcm.GcmReceiver" 
      android:exported="true" 
      android:permission="com.google.android.c2dm.permission.SEND" > 
      <intent-filter> 
       <action android:name="android.intent.action.BOOT_COMPLETED"/> 
       <action android:name="com.google.android.c2dm.intent.RECEIVE" /> 
       <!-- for Gingerbread GSF backward compat --> 
       <action android:name="com.google.android.c2dm.intent.REGISTRATION" /> 
       <category android:name="com.flagg327.guicomaipu" /> 
      </intent-filter> 
     </receiver> 

     <service 
      android:name="com.flagg327.guicomaipu.gcm.RegistrationService" 
      android:exported="false" /> 

     <service 
      android:name="com.flagg327.guicomaipu.gcm.TokenRefreshListenerService" 
     android:exported="false"> 
      <intent-filter> 
       <action 
        android:name="com.google.android.gms.iid.InstanceID" /> 
      </intent-filter> 
     </service> 

     <service 
      android:name="com.flagg327.guicomaipu.gcm.NotificacionsListenerService" 
     android:exported="false" > 
      <intent-filter> 
       <action android:name="com.google.android.c2dm.intent.RECEIVE" /> 
      </intent-filter> 
     </service> 

    </aplication> 

    <permission 
     android:name="com.flagg327.guicomaipu.C2D_MESSAGE" 
      android:protectionLevel="signature" /> 
    <uses-permission android:name="com.flagg327.guicomaipu.permission.C2D_MESSAGE" /> 
    <uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" /> 
    <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/> 

TokenRefreshListenerService.java

每天登记 '令牌' 更新。因此,每个使用GCM的Android应用都必须有一个InstanceIDListenerService来管理这些更新。

public class TokenRefreshListenerService extends InstanceIDListenerService{ 

    @Override 
    public void onTokenRefresh() { 
     // Launch the registration process. 
     Intent i = new Intent(this, RegistrationService.class); 
     startService(i); 
    } 
} 

NotificacionsListenerService.java

GCM自动显示的推送通知,但只有当相关联的应用程序有一个GCMListenerService

public class NotificacionsListenerService extends GcmListenerService { 

    @Override 
    public void onMessageReceived(String from, Bundle data) { 
     Log.d("A", "onMessageReceived()"); 

     // Do something 

    } 
} 

RegistrationService.java

GCM识别Android设备使用情况g注册卡('令牌')。我的应用程序应该能够从安装它的每个Android设备注册。

public class RegistrationService extends IntentService { 

    /** 
    * Constructor 
    */ 
    public RegistrationService() { 
     super("RegistrationService"); 
    } 

    @Override 
    protected void onHandleIntent(Intent intent) { 
     // Generate or download the registration 'token'. 
     InstanceID myID = InstanceID.getInstance(this); 

     String registrationToken = null; 
     try { 
      // Get the registration 'token'. 
      registrationToken = myID.getToken(
        getString(R.string.gcm_defaultSenderId), 
        GoogleCloudMessaging.INSTANCE_ID_SCOPE, 
        null 
      ); 

      // Subscribe to a topic. The app is able now to receive notifications from this topic. 
      GcmPubSub subscription = GcmPubSub.getInstance(this); 
      subscription.subscribe(registrationToken, "/topics/guico_maipu_topic", null); 
     } catch (IOException e) { 
      e.printStackTrace(); 
     } 

     Log.e("Registration Token", registrationToken); 
    } 
} 

错误

,当我通过Python发送推送通知,将出现此错误。

09-13 21:21:44.800 1851-1851/? W/GCM-DMM: broadcast intent callback: result=CANCELLED forIntent { act=com.google.android.c2dm.intent.RECEIVE pkg=com.flagg327.guicomaipu (has extras) } 

昨天工作...任何想法?比你的时间。

+0

从此[线程]根据(https://groups.google.com/forum/#!msg/android-gcm/MqVlA3Sj26c/6O4TdU1pm0UJ),当接收应用程序是在停止发生此问题设备上的状态(例如,通过设置强制停止)。手动启动时,它只会再次开始接收消息。你也可以检查这[相关SO帖子](http://stackoverflow.com/questions/11902947/broadcast-intent-callback-result-cancelled-forintent)。 – abielita

+0

Sloved检查此..https://stackoverflow.com/a/45810771/1993001 –

回答

7

所以......我解决了这个问题。问题在于如果应用程序强制关闭或者设备启动后应用程序从未打开过,则设备未注册为接收GCM。解决方案很简单,在手机启动时注册设备。为此,我实施了一个BroadcastReceiver,并在其中启动了一个流程注册。

的修改:

加入AndroidManifest

<receiver android:name="com.flagg327.guicomaipu.gcm.OnBootBroadcastReceiver"> 
     <intent-filter > 
      <action android:name="android.intent.action.BOOT_COMPLETED" /> 

      <category android:name="android.intent.category.HOME" /> 
     </intent-filter> 
    </receiver> 

OnBootBroadcastReceiver.java

public class OnBootBroadcastReceiver extends BroadcastReceiver { 
    @Override 
    public void onReceive(Context context, Intent intent) { 

     Intent i = new Intent("com.flagg327.guicomaipu.gcm.RegistrationService"); 
     i.setClass(context, RegistrationService.class); 
     context.startService(i); 
    } 
} 

因此,在引导时,设备会注册到GCM服务器中去能够从我的服务器接收任何推送通知。我希望它是有用的。

+0

谢谢@ flagg327,我是同样的问题,并通过您的答案解决它。 –

+4

当我们强制杀死应用程序时,这是否工作? –

7

我得到了同样的错误

09-13 21:21:44.800 1851-1851/? W/GCM-DMM: broadcast intent callback: result=CANCELLED forIntent { act=com.google.android.c2dm.intent.RECEIVE pkg=com.XXX.XXX (has extras) } 

查杀应用之后。

经过一番研究,我意识到,这只是一个“调试问题”。即使应用程序已关闭,“已签名APK”也能正确处理广播。

希望它有帮助!

+5

它没有为我工作。 :( –

+0

请链接您的资源的来源 – natanavra

+0

@natanavra这是什么意思?完整的源代码已经在原始问题 - 是不是? – niggeulimann

3

深入探讨这种情况后,看起来会发生这种情况,如果您从Android Studio中终止应用程序。

如果您从启动器中打开应用程序并将其滑开,您的应用程序仍会收到通知。

(在带有FCM的OnePlus One上测试不是GCM)

+1

这帮了我很多,谢谢。 – gorkem

0

我也遇到过这个问题。当我从堆栈中删除应用程序时,推送通知未收到。大量谷歌后,我发现很少有手机具有电池优化功能,这将禁用后台运行的应用程序。当我启用时,我的应用程序也可以在后台运行。推送通知正常工作。只有很少的应用程序,如What's application等,只能有默认启用功能。你可以看看下面这个URL。

https://github.com/firebase/quickstart-android/issues/89

相关问题