Android 14 (API 수준 34)부터는 각 포그라운드 서비스에 적절한 서비스 유형을 선언해야 합니다. 즉, 앱 매니페스트에서 서비스 유형을 선언하고 해당 유형에 적합한 포그라운드 서비스 권한을 요청해야 합니다 (FOREGROUND_SERVICE 권한 요청 외에). 또한 포그라운드 서비스 유형에 따라 서비스를 실행하기 전에 런타임 권한을 요청해야 할 수도 있습니다.
카메라
- 要在清单中
android:foregroundServiceType下声明的前台服务类型 camera- 要在清单中声明的权限
FOREGROUND_SERVICE_CAMERA- 要传递给
startForeground()的常量 FOREGROUND_SERVICE_TYPE_CAMERA- 运行时前提条件
请求并被授予
CAMERA运行时权限- 说明
继续在后台访问相机,例如支持多任务的视频聊天应用。
연결된 기기
- 要在清单中的以下位置声明的前台服务类型
android:foregroundServiceTypeconnectedDevice- 在清单中声明的权限
FOREGROUND_SERVICE_CONNECTED_DEVICE- 要传递给
startForeground()的常量 FOREGROUND_SERVICE_TYPE_CONNECTED_DEVICE- 运行时前提条件
必须至少满足以下其中一个条件:
在清单中至少声明以下其中一项权限:
至少请求并被授予以下其中一项运行时权限:
- 说明
与需要蓝牙、NFC、IR、USB 或网络连接的外部设备进行互动。
- 替代方案
如果您的应用需要向外部设备持续传输数据,请考虑改用配套设备管理器。使用配套设备感知 API,可帮助您的应用在配套设备在范围内时保持运行。
如果您的应用需要扫描蓝牙设备,请考虑改用 Bluetooth Scan API。
데이터 동기화
- 要在清单中声明的前台服务类型,位于
android:foregroundServiceTypedataSync- 要在清单中声明的权限
FOREGROUND_SERVICE_DATA_SYNC- 要传递给
startForeground()的常量 FOREGROUND_SERVICE_TYPE_DATA_SYNC- 运行时前提条件
- 无
- 说明
数据传输操作,例如:
- 数据上传或下载
- 备份和恢复操作
- 导入或导出操作
- 获取数据
- 本地文件处理
- 通过网络在设备和云端之间传输数据
- 替代方案
如需了解详情,请参阅数据同步前台服务的替代方案。
Health
- 要在清单中的以下位置声明的前台服务类型
android:foregroundServiceTypehealth- 在清单中声明的权限
FOREGROUND_SERVICE_HEALTH- 要传递给
startForeground()的常量 FOREGROUND_SERVICE_TYPE_HEALTH- 运行时前提条件
必须至少满足以下其中一个条件:
在清单中声明
HIGH_SAMPLING_RATE_SENSORS权限。至少请求并被授予以下其中一项运行时权限:
- 说明
为健身类别的应用(例如锻炼追踪器)提供支持的所有长时间运行的用例。
위치
- 매니페스트에서 선언할 포그라운드 서비스 유형
android:foregroundServiceTypelocation- 매니페스트에서 선언할 권한
FOREGROUND_SERVICE_LOCATIONstartForeground()에 전달할 상수FOREGROUND_SERVICE_TYPE_LOCATION- 런타임 기본 요건
사용자는 위치 서비스를 사용 설정해야 하며 앱에 다음 런타임 권한 중 하나 이상이 부여되어야 합니다.
- 설명
탐색 및 위치 공유와 같이 위치 액세스가 필요한 장기 실행 사용 사례
- 대안
사용자가 특정 위치에 도달할 때 앱이 트리거되어야 하는 경우 대신 geofence API를 사용하는 것이 좋습니다.
미디어
- 要在清单中声明的前台服务类型,位于
android:foregroundServiceTypemediaPlayback- 要在清单中声明的权限
FOREGROUND_SERVICE_MEDIA_PLAYBACK- 要传递给
startForeground()的常量 FOREGROUND_SERVICE_TYPE_MEDIA_PLAYBACK- 运行时前提条件
- 无
- 说明
在后台继续播放音频或视频。在 Android TV 上支持数字视频录制 (DVR) 功能。
- 替代方案
如果您要显示画中画视频,请使用画中画模式。
미디어 처리 중
- 매니페스트에서 선언할 포그라운드 서비스 유형
android:foregroundServiceTypemediaProcessing- 매니페스트에서 선언할 권한
FOREGROUND_SERVICE_MEDIA_PROCESSINGstartForeground()에 전달할 상수FOREGROUND_SERVICE_TYPE_MEDIA_PROCESSING- 런타임 기본 요건
- 없음
- 설명
미디어를 다른 형식으로 변환하는 등 미디어 저작물에 시간이 많이 걸리는 작업을 실행하는 서비스입니다. 시스템은 이 서비스가 실행되는 시간을 제한합니다. 일반적으로 이 시간 제한은 24시간 중 6시간입니다. 이 한도는 앱의 모든
mediaProcessing포그라운드 서비스에서 공유됩니다.앱은 다음 시나리오에서 미디어 처리 서비스를 수동으로 중지해야 합니다.
- 트랜스코딩 작업이 완료되거나 실패 상태에 도달하면 서비스가
Service.stopForeground()및Service.stopSelf()를 호출하여 서비스를 완전히 중지하도록 합니다.
- 트랜스코딩 작업이 완료되거나 실패 상태에 도달하면 서비스가
제한 시간에 도달하면 시스템은 서비스의
Service.onTimeout(int, int)메서드를 호출합니다. 이때 서비스는Service.stopSelf()를 호출할 수 있는 몇 초의 시간이 있습니다. 서비스가Service.stopSelf()를 호출하지 않으면 '<fgs_type>의 포그라운드 서비스가 제한 시간 내에 중지되지 않았습니다. <component_name>'라는 오류 메시지와 함께 ANR이 발생합니다.참고:
Service.onTimeout(int, int)는 Android 14 이하에서는 사용할 수 없습니다. 이러한 버전을 실행하는 기기에서 미디어 처리 서비스가 제한 시간에 도달하면 시스템은 즉시 앱을 캐시합니다. 따라서 앱은 제한 시간 알림을 받기 위해 기다리지 않아야 합니다. 대신 포그라운드 서비스를 종료하거나 적절한 시점에 백그라운드 서비스로 변경해야 합니다.
미디어 프로젝션
- 要在清单中声明的前台服务类型,位于
android:foregroundServiceTypemediaProjection- 要在清单中声明的权限
FOREGROUND_SERVICE_MEDIA_PROJECTION- 要传递给
startForeground()的常量 FOREGROUND_SERVICE_TYPE_MEDIA_PROJECTION- 运行时前提条件
在启动前台服务之前,调用
createScreenCaptureIntent()方法。这样做会向用户显示权限通知;用户必须授予权限,您才能创建服务。创建前台服务后,您可以调用
MediaProjectionManager.getMediaProjection()。- 说明
使用
MediaProjectionAPI 将内容投影到非主要显示屏或外部设备。这些内容不必全都为媒体内容。- 替代方案
如需将媒体内容流式传输到其他设备,请使用 Google Cast SDK。
마이크
- 매니페스트에서
android:foregroundServiceTypemicrophone- 매니페스트에서 선언할 권한
FOREGROUND_SERVICE_MICROPHONEstartForeground()에 전달할 상수FOREGROUND_SERVICE_TYPE_MICROPHONE- 런타임 기본 요건
RECORD_AUDIO런타임 권한을 요청하고 부여받습니다.- 설명
음성 녹음기 또는 통신 앱과 같이 백그라운드에서 마이크 캡처를 계속합니다.
전화 통화
- 要在清单中声明的前台服务类型,位于
android:foregroundServiceTypephoneCall- 要在清单中声明的权限
FOREGROUND_SERVICE_PHONE_CALL- 要传递给
startForeground()的常量 FOREGROUND_SERVICE_TYPE_PHONE_CALL- 运行时前提条件
必须至少满足以下其中一个条件:
- 应用已在其清单文件中声明
MANAGE_OWN_CALLS权限。
- 应用已在其清单文件中声明
- 应用通过
ROLE_DIALER角色成为默认的拨号器应用。
- 应用通过
- 说明
使用
ConnectionServiceAPI 继续当前通话。- 替代方案
如果您需要拨打手机、视频或 VoIP 电话,不妨考虑使用
android.telecom库。考虑使用
CallScreeningService来过滤来电。
원격 메시지
- 매니페스트에서 선언할 포그라운드 서비스 유형
android:foregroundServiceTyperemoteMessaging- 매니페스트에서 선언할 권한
FOREGROUND_SERVICE_REMOTE_MESSAGINGstartForeground()에 전달할 상수FOREGROUND_SERVICE_TYPE_REMOTE_MESSAGING- 런타임 기본 요건
- 없음
- 설명
- 문자 메시지를 한 기기에서 다른 기기로 전송합니다. 사용자가 기기를 전환할 때 사용자의 메시지 작업의 연속성을 지원합니다.
짧은 서비스
- 매니페스트에서 선언할 포그라운드 서비스 유형
android:foregroundServiceTypeshortService- 매니페스트에서 선언할 권한
- 없음
startForeground()에 전달할 상수FOREGROUND_SERVICE_TYPE_SHORT_SERVICE- 런타임 기본 요건
- 없음
- 설명
중단하거나 연기할 수 없는 중요한 작업을 신속하게 완료합니다.
이 유형에는 몇 가지 고유한 특성이 있습니다.
- 짧은 기간(약 3분) 동안만 실행할 수 있습니다.
- 고정 포그라운드 서비스는 지원되지 않습니다.
- 다른 포그라운드 서비스는 시작할 수 없습니다.
- 유형별 권한은 필요하지 않지만
FOREGROUND_SERVICE권한은 필요합니다. shortService는 앱이 현재 새 포그라운드 서비스를 시작할 수 있는 경우에만 다른 서비스 유형으로 변경할 수 있습니다.- 포그라운드 서비스는 언제든지 유형을
shortService로 변경할 수 있으며 이때 제한 시간 기간이 시작됩니다.
shortService의 제한 시간은
Service.startForeground()가 호출되는 시점부터 시작됩니다. 앱은 제한 시간이 발생하기 전에Service.stopSelf()또는Service.stopForeground()를 호출해야 합니다. 그러지 않으면 새Service.onTimeout()이 호출되어 앱이stopSelf()또는stopForeground()를 호출하여 서비스를 중지할 수 있는 짧은 기회를 제공합니다.Service.onTimeout()이 호출되고 잠시 후에 앱이 캐시된 상태가 되고 사용자가 앱과 활발하게 상호작용하지 않는 한 더 이상 포그라운드에 있는 것으로 간주되지 않습니다. 앱이 캐시되고 서비스가 중지되지 않은 잠시 후에 앱이 ANR을 수신합니다. ANR 메시지에서FOREGROUND_SERVICE_TYPE_SHORT_SERVICE를 언급합니다. 이러한 이유로Service.onTimeout()콜백을 구현하는 것이 좋습니다.Android 13 이하에는
Service.onTimeout()콜백이 없습니다. 이러한 기기에서 동일한 서비스가 실행되는 경우 제한 시간과 ANR을 모두 수신하지 않습니다. 아직Service.onTimeout()콜백을 수신하지 않았더라도 처리 작업이 완료되는 즉시 서비스가 중지되는지 확인합니다.shortService의 제한 시간이 준수되지 않으면 앱에 유효한 다른 포그라운드 서비스나 다른 앱 수명 주기 프로세스가 실행 중이더라도 ANR이 발생한다는 점에 유의해야 합니다.앱이 사용자에게 표시되거나 포그라운드 서비스가 백그라운드에서 시작되도록 허용하는 예외 중 하나를 충족하는 경우
FOREGROUND_SERVICE_TYPE_SHORT_SERVICE매개변수로Service.StartForeground()를 다시 호출하면 제한 시간이 3분 더 연장됩니다. 앱이 사용자에게 표시되지 않고 예외 중 하나를 충족하지 않는 경우 유형과 관계없이 다른 포그라운드 서비스를 시작하려고 하면ForegroundServiceStartNotAllowedException이 발생합니다.사용자가 앱의 배터리 최적화를 사용 중지해도 shortService FGS의 제한 시간에 영향을 받습니다.
shortService유형과 다른 포그라운드 서비스 유형이 포함된 포그라운드 서비스를 시작하면 시스템에서shortService유형 선언을 무시합니다. 그러나 서비스는 여전히 선언된 다른 유형의 기본 요건을 준수해야 합니다. 자세한 내용은 포그라운드 서비스 문서를 참고하세요.
특수 용도
- 매니페스트에서 선언할 포그라운드 서비스 유형
android:foregroundServiceTypespecialUse- 매니페스트에서 선언할 수 있는 권한
FOREGROUND_SERVICE_SPECIAL_USEstartForeground()에 전달할 상수FOREGROUND_SERVICE_TYPE_SPECIAL_USE- 런타임 기본 요건
- 없음
- 설명
다른 포그라운드 서비스 유형에서 다루지 않는 유효한 포그라운드 서비스 사용 사례를 다룹니다.
개발자는
FOREGROUND_SERVICE_TYPE_SPECIAL_USE포그라운드 서비스 유형을 선언하는 것 외에도 매니페스트에서 사용 사례를 선언해야 합니다. 이렇게 하려면<service>요소 내에서<property>요소를 지정해야 합니다. 이러한 값과 해당 사용 사례는 Google Play Console에서 앱을 제출할 때 검토됩니다. 용도 제공하는 케이스는 자유 형식이므로specialUse를 사용해야 하는 이유를 검토자가 알 수 있도록 관련 정보 있습니다.<service android:name="fooService" android:foregroundServiceType="specialUse"> <property android:name="android.app.PROPERTY_SPECIAL_USE_FGS_SUBTYPE" android:value="explanation_for_special_use"/> </service>
시스템 제외됨
- 要在其清单中声明的前台服务类型
android:foregroundServiceTypesystemExempted- 在清单中声明的权限
FOREGROUND_SERVICE_SYSTEM_EXEMPTED- 要传递给
startForeground()的常量 FOREGROUND_SERVICE_TYPE_SYSTEM_EXEMPTED- 运行时前提条件
- 无
- 说明
为系统应用和特定系统集成预留,以便继续使用前台服务。
如需使用此类型,应用必须至少满足以下条件之一:
- 设备处于演示模式状态
- 应用是设备所有者
- 应用是性能分析器所有者
- 属于具有
ROLE_EMERGENCY角色的安全应用 - 属于设备管理应用
- 具有
SCHEDULE_EXACT_ALARM或USE_EXACT_ALARM权限的应用 VPN 应用(通过设置 > 网络和互联网 > VPN 进行配置)
否则,声明此类型会导致系统抛出
ForegroundServiceTypeNotAllowedException。
포그라운드 서비스 유형 사용에 관한 Google Play 정책 시행
앱이 Android 14 이상을 타겟팅하는 경우 Play Console의 앱 콘텐츠 페이지 (정책 > 앱 콘텐츠)에서 앱의 포그라운드 서비스 유형을 선언해야 합니다. Play Console에서 포그라운드 서비스 유형을 선언하는 방법에 관한 자세한 내용은 포그라운드 서비스 및 전체 화면 인텐트 요구사항 이해하기를 참고하세요.