IT박스

권한 거부 : startForeground에는 android.permission.FOREGROUND_SERVICE가 필요합니다.

itboxs 2020. 6. 13. 19:33
반응형

권한 거부 : startForeground에는 android.permission.FOREGROUND_SERVICE가 필요합니다.


최근에 우리는 갑자기 다음과 같은 몇 가지 스택 추적을보고있었습니다. 왜 그런가요? 앱이 미디어 알림 및 모든 내용으로 오디오 설명 서비스를 포 그라운드로 이동하려고 할 때 발생합니다.

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)

릴리스 노트를 제대로 읽지 않으면 얻을 수있는 것입니다. 이것은 설정 targetSdkVersion = 28(Android 9 / Pie)에서 시작되었으며 마이그레이션 노트 와 같이 명확하게 설명되어 있습니다 .

포 그라운드 서비스를 사용하려는 앱은 이제 먼저 FOREGROUND_SERVICE 권한을 요청해야합니다. 이것은 일반적인 권한이므로 시스템이 요청하는 앱에 자동으로 권한을 부여합니다. 권한없이 포 그라운드 서비스를 시작하면 SecurityException이 발생합니다.

따라서 해결책은 다음을 추가하는 것입니다 AndroidManifest.xml.

<manifest ...>
     ...
     <uses-permission android:name="android.permission.FOREGROUND_SERVICE" />
     ...
     <application ...>
     ...
</manifest>

권한 거부 : startForeground에는 android.permission.FOREGROUND_SERVICE가 필요합니다.

Android 9 (API 레벨 28) 이상을 대상으로하고 포 그라운드 서비스를 사용하는 앱은을 요청해야합니다 FOREGROUND_SERVICE permission.

이제 매니페스트 파일에 Foreground 서비스 권한 을 추가해야 합니다.

  • 일반 응용 프로그램을 사용할 수 있습니다 Service.startForeground

견본

<uses-permission android:name="android.permission.FOREGROUND_SERVICE" />

FOREGROUND_SERVICE 일반 권한이므로 시스템에서 요청하는 앱에 자동으로 권한을 부여합니다.

Android 9 / Pie의 마이그레이션 노트를 확인하십시오.

  • 변화

포 그라운드 서비스 권한

  • 요약

포 그라운드 서비스를 사용하려는 앱은 이제 먼저 FOREGROUND_SERVICE 권한을 요청해야합니다. 이것은 일반적인 권한이므로 시스템이 요청하는 앱에 자동으로 권한을 부여합니다. 권한없이 포 그라운드 서비스를 시작하면 SecurityException이 발생합니다.

또한 읽기 startForeground()

  • 이 API를 사용 Build.VERSION_CODES.P하려면 API 이상을 대상으로하는 앱 이 권한 Manifest.permission.FOREGROUND_SERVICE요청해야합니다 .

참고 URL : https://stackoverflow.com/questions/52382710/permission-denial-startforeground-requires-android-permission-foreground-servic

반응형