최근에 우리는 갑자기 다음과 같은 몇 가지 스택 추적을보고있었습니다. 왜 그런가요? 앱이 미디어 알림 및 모든 내용으로 오디오 설명 서비스를 포 그라운드로 이동하려고 할 때 발생합니다.
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
권한을.
에서 마이그레이션 노트 안드로이드 9 :
포 그라운드 서비스를 사용하려는 앱은 이제 먼저 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
을 요청해야합니다 .
답변
API 레벨 28 이상의 경우 FOREGROUND_SERVICE 권한이 필요합니다. 그렇지 않으면 실행할 수 없으며 예외가 발생합니다.
추가하면 해결됩니다
<uses-permission android:name="android.permission.FOREGROUND_SERVICE" />
AndroidManifest.xml 파일에서.
답변
targetSdkVersion
최소한의는 28
Play 스토어에서 앱 업데이트 2019년 11월 1일에서 필수가 될 것입니다. 따라서 대상 API를 변경 한 다음 FOREGROUND_SERVICE
충돌이 발생하지 않도록 권한 을 요청 해야합니다.startForeground()
답변
그를 주목하는 것은 FOREGROUND_SERVICE
실행 권한 요구 사항을 필요로하지 않습니다. 매니페스트에만 아래에 추가
<uses-permission android:name="android.permission.FOREGROUND_SERVICE" />
위의 줄은 전에 추가해야합니다 <application