Ostatnio widzimy nagle kilka następujących śladów stosu. Dlaczego tak może być? Dzieje się tak, gdy aplikacja próbuje przenieść na pierwszy plan usługę komentarza audio z powiadomieniem medialnym i wszystkim innym.
java.lang.SecurityException: Permission Denial: startForeground from pid=1824, uid=10479 requires android.permission.FOREGROUND_SERVICE
at android.os.Parcel.createException(Parcel.java:1942)
at android.os.Parcel.readException(Parcel.java:1910)
at android.os.Parcel.readException(Parcel.java:1860)
at android.app.IActivityManager$Stub$Proxy.setServiceForeground(IActivityManager.java:5198)
at android.app.Service.startForeground(Service.java:695)
at com.example.app.services.AudioService.setUpMediaNotification(AudioService.java:372)
at com.example.app.services.AudioService.setUpAndStartAudioFeed(AudioService.java:328)
at com.example.app.services.AudioService.onStartCommand(AudioService.java:228)
at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:3667)
at android.app.ActivityThread.access$1600(ActivityThread.java:199)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1681)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loop(Looper.java:193)
at android.app.ActivityThread.main(ActivityThread.java:6669)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)
Caused by: android.os.RemoteException: Remote stack trace:
at com.android.server.am.ActivityManagerService.enforcePermission(ActivityManagerService.java:9186)
at com.android.server.am.ActiveServices.setServiceForegroundInnerLocked(ActiveServices.java:1189)
at com.android.server.am.ActiveServices.setServiceForegroundLocked(ActiveServices.java:870)
at com.android.server.am.ActivityManagerService.setServiceForeground(ActivityManagerService.java:20434)
at android.app.IActivityManager$Stub.onTransact(IActivityManager.java:976)
źródło
targetSdkVersion
ma mniej niż 28, nie potrzebujemy żadnego pozwolenia na uruchamianie usług Foreground na urządzeniach z 28?maxSdkVersion
.Aplikacje kierowane na system Android 9 (poziom API 28) lub wyższy i korzystające z usług pierwszego planu muszą poprosić o
FOREGROUND_SERVICE permission
.Więc teraz musimy dodać pozwolenie na serwis Foreground w pliku manifestu
Service.startForeground
PRÓBA
Sprawdź notatki migracji systemu Android 9 / Pie
Przeczytaj także
startForeground()
Build.VERSION_CODES.P
lub nowszy muszą poprosić o pozwolenieManifest.permission.FOREGROUND_SERVICE
, aby korzystać z tego interfejsu API.źródło
W przypadku interfejsu API poziomu 28 lub nowszego wymaga pozwolenia FOREGROUND_SERVICE. W przeciwnym razie nie będzie można uruchomić i uzyskał wyjątek.
Zostanie to rozwiązane poprzez dodanie
w pliku AndroidManifest.xml.
źródło
targetSdkVersion
Przynajmniej28
będzie obowiązkowe od 1 listopada 2019 do aktualizacji aplikacji w Sklepie Play. Musisz więc zmienić docelowy interfejs API, a następnie poprosić o pozwolenie,FOREGROUND_SERVICE
aby uniknąć awariistartForeground()
źródło
Należy zauważyć, że
FOREGROUND_SERVICE
nie wymaga to wymogu posiadania uprawnień do wykonywania. dodaj tylko poniżej do Manifestówpowyższą linię należy dodać wcześniej
<application
źródło