Почему приложение не может получать уведомления GCM в Android O? - PullRequest
0 голосов
/ 05 июня 2019

Я использую GCM внутри своего приложения.Но в Android O приложение перестает получать уведомления, если оно уходит в фоновый режим.Я использую StartService для нижнего API 26 и StartForgroundService для верхних API 26 для устройств Android.Также пробовал JobSchedular и JobIntentService, но приложение по-прежнему аварийно завершает работу со следующей ошибкой.

Caused by: java.lang.IllegalStateException: Not allowed to start service Intent { act=com.google.android.c2dm.intent.RECEIVE flg=0x1000010 pkg=com.teacout.devzspoon cmp=com.teacout.devzspoon/com.devzspoon.services.MyGcmListenerService (has extras) }: app is in background uid UidRecord{cf40c05 u0a582 RCVR bg:+2m52s193ms idle change:uncached procs:1 proclist:22992, seq(0,0,0)}
                                                                           at android.app.ContextImpl.startServiceCommon(ContextImpl.java:1600)
                                                                           at android.app.ContextImpl.startService(ContextImpl.java:1546)
                                                                           at android.content.ContextWrapper.startService(ContextWrapper.java:669)
                                                                           at android.content.ContextWrapper.startService(ContextWrapper.java:669)
                                                                           at android.support.v4.content.WakefulBroadcastReceiver.startWakefulService(WakefulBroadcastReceiver.java:99)
                                                                           at com.google.android.gms.gcm.GcmReceiver.zzf(Unknown Source:23)
                                                                           at com.google.android.gms.gcm.GcmReceiver.zze(Unknown Source:0)
                                                                           at com.google.android.gms.gcm.GcmReceiver.onReceive(Unknown Source:106)
                                                                           at android.app.ActivityThread.handleReceiver(ActivityThread.java:3406)
                                                                           at android.app.ActivityThread.-wrap18(Unknown Source:0) 
                                                                           at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1807) 
                                                                           at android.os.Handler.dispatchMessage(Handler.java:106) 
                                                                           at android.os.Looper.loop(Looper.java:164) 
                                                                           at android.app.ActivityThread.main(ActivityThread.java:7000) 
                                                                           at java.lang.reflect.Method.invoke(Native Method) 
                                                                           at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:441) 
                                                                           at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1408) 
06-05 17:30:40.508 22992-22992/com.teacout.devzspoon E/UncaughtException: java.lang.RuntimeException: Unable to start receiver com.google.android.gms.gcm.GcmReceiver: java.lang.IllegalStateException: Not allowed to start service Intent { act=com.google.android.c2dm.intent.RECEIVE flg=0x1000010 pkg=com.teacout.devzspoon cmp=com.teacout.devzspoon/com.devzspoon.services.MyGcmListenerService (has extras) }: app is in background uid UidRecord{cf40c05 u0a582 RCVR bg:+2m52s193ms idle change:uncached procs:1 proclist:22992, seq(0,0,0)}
                                                                              at android.app.ActivityThread.handleReceiver(ActivityThread.java:3413)
                                                                              at android.app.ActivityThread.-wrap18(Unknown Source:0)
                                                                              at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1807)
                                                                              at android.os.Handler.dispatchMessage(Handler.java:106)
                                                                              at android.os.Looper.loop(Looper.java:164)
                                                                              at android.app.ActivityThread.main(ActivityThread.java:7000)
                                                                              at java.lang.reflect.Method.invoke(Native Method)
                                                                              at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:441)
                                                                              at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1408)
...