포그라운드 서비스 유형은 필수 항목임

개발자가 사용자 대상 포그라운드 서비스를 더 잘 정의하도록 돕기 위해 Android 10에서는 <service> 요소 내에 android:foregroundServiceType 속성을 도입했습니다.

앱이 Android 14를 타겟팅하는 경우 적절한 포그라운드 서비스 유형을 지정해야 합니다. 이전 버전의 Android에서와 마찬가지로 여러 유형을 결합할 수 있습니다. 이 목록에는 선택할 수 있는 포그라운드 서비스 유형이 표시됩니다.

앱의 사용 사례가 이러한 유형과 연결되어 있지 않으면 WorkManager 또는 사용자가 시작한 데이터 전송 작업을 사용하도록 로직을 이전하는 것이 좋습니다.

health, remoteMessaging, shortService, specialUsesystemExempted 유형은 Android 14에 새로 도입되었습니다.

다음 코드 스니펫은 매니페스트에서 포그라운드 서비스 유형을 선언하는 예를 보여줍니다.

<manifest ...>
  <uses-permission android:name="android.permission.FOREGROUND_SERVICE" />
  <uses-permission android:name="android.permission.FOREGROUND_SERVICE_MEDIA_PLAYBACK" />
    <application ...>
      <service
          android:name=".MyMediaPlaybackService"
          android:foregroundServiceType="mediaPlayback"
          android:exported="false">
      </service>
    </application>
</manifest>

Android 14를 타겟팅하는 앱이 매니페스트에서 특정 서비스의 유형을 정의하지 않으면 시스템은 해당 서비스의 startForeground() 호출 시 MissingForegroundServiceTypeException을 발생시킵니다.

포그라운드 서비스 유형을 사용할 새로운 권한 선언

Android 14를 타겟팅하는 앱이 포그라운드 서비스를 사용하는 경우 앱은 Android 14에 도입된 포그라운드 서비스 유형에 따라 특정 권한을 선언해야 합니다. 이러한 권한은 이 페이지의 각 포그라운드 서비스 유형의 의도된 사용 사례 및 시행 섹션에 있는 '매니페스트 파일에서 선언해야 하는 권한' 섹션에 표시됩니다.

모든 권한은 일반 권한으로 정의되며 기본적으로 부여됩니다. 사용자는 이러한 권한을 취소할 수 없습니다.

런타임에 포그라운드 서비스 유형 포함

对于启动前台服务的应用,最佳实践是使用 ServiceCompat 版本的 startForeground()(适用于 androidx-core 1.12 及更高版本),并在其中传入前台服务类型的按位整数。您可以选择传递一个或多个类型值。

通常,您应仅声明特定用例所需的类型。这样可以更轻松地满足系统对每种前台服务类型的预期。如果某项前台服务以多种类型启动,则该前台服务必须遵守所有类型的平台强制执行要求

ServiceCompat.startForeground(0, notification, FOREGROUND_SERVICE_TYPE_LOCATION)

如果调用中未指定前台服务类型,则该类型默认为清单中定义的值。如果您没有在清单中指定服务类型,系统会抛出 MissingForegroundServiceTypeException

如果前台服务在您启动后需要新的权限,您应再次调用 startForeground() 并添加新的服务类型。例如,假设健身应用运行一项跑步跟踪器服务,该服务始终需要 location 信息,但不一定需要 media 权限。您需要在清单中同时声明 locationmediaPlayback。如果用户开始跑步并且只想跟踪其位置,您的应用应调用 startForeground() 并仅传递 location 服务类型。然后,如果用户想要开始播放音频,请再次调用 startForeground() 并传递 location|mediaPlayback

시스템 런타임 검사

The system checks for proper use of foreground service types and confirms that the app has requested the proper runtime permissions or uses the required APIs. For instance, the system expects apps that use the foreground service type FOREGROUND_SERVICE_TYPE_LOCATION type to request either ACCESS_COARSE_LOCATION or ACCESS_FINE_LOCATION.

This implies that apps must follow a very specific order of operations when requesting permissions from the user and starting foreground services. Permissions must be requested and granted before the app attempts to call startForeground(). Apps that request the appropriate permissions after the foreground service has been started must change this order of operations and request the permission before starting the foreground service.

The specifics of platform enforcement appear in the sections labeled "runtime requirements" in the intended use cases and enforcement for each foreground service type section on this page.

각 포그라운드 서비스 유형의 의도된 사용 사례 및 시행

지정된 포그라운드 서비스 유형을 사용하려면 매니페스트 파일에서 특정 권한을 선언하고 특정 런타임 요구사항을 충족해야 하며 앱은 해당 유형의 의도된 사용 사례 세트 중 하나를 충족해야 합니다. 다음 섹션에서는 선언해야 하는 권한, 런타임 기본 요건, 각 유형의 의도된 사용 사례를 설명합니다.

카메라

매니페스트에서 android:foregroundServiceType 아래 선언할 포그라운드 서비스 유형
camera
매니페스트에서 선언할 권한
FOREGROUND_SERVICE_CAMERA
startForeground()에 전달할 상수
FOREGROUND_SERVICE_TYPE_CAMERA
런타임 기본 요건

CAMERA 런타임 권한 요청 및 부여

참고: CAMERA 런타임 권한에는 사용 중 제한사항이 적용됩니다. 이러한 이유로 몇 가지 예외를 제외하고 앱이 백그라운드에 있는 동안에는 camera 포그라운드 서비스를 만들 수 없습니다. 자세한 내용은 사용 중 권한이 필요한 포그라운드 서비스 시작 제한사항을 참고하세요.

설명

멀티태스킹을 허용하는 영상 채팅 앱과 같이 백그라운드에서 카메라에 계속 액세스합니다.

연결된 기기

매니페스트에서 선언할 포그라운드 서비스 유형
android:foregroundServiceType
connectedDevice
매니페스트에서 선언할 권한
FOREGROUND_SERVICE_CONNECTED_DEVICE
startForeground()에 전달할 상수
FOREGROUND_SERVICE_TYPE_CONNECTED_DEVICE
런타임 기본 요건

다음 조건 중 하나 이상에 해당해야 합니다.

설명

블루투스, NFC, IR, USB 또는 네트워크 연결이 필요한 외부 기기와의 상호작용입니다.

대안

앱에서 외부 기기로 데이터를 계속 전송해야 한다면 대신 호환 기기 관리자를 사용해 보세요. 호환 기기 접속 상태 API를 사용하면 호환 기기가 범위 내에 있는 동안 앱이 계속 실행되도록 할 수 있습니다.

앱에서 블루투스 기기를 검색해야 한다면 대신 블루투스 검색 API를 사용해 보세요.

데이터 동기화

매니페스트에서 선언할 포그라운드 서비스 유형
android:foregroundServiceType
dataSync
매니페스트에서 선언할 권한
FOREGROUND_SERVICE_DATA_SYNC
startForeground()에 전달할 상수
FOREGROUND_SERVICE_TYPE_DATA_SYNC
런타임 기본 요건
없음
설명

다음과 같은 데이터 전송 작업입니다.

  • 데이터 업로드 또는 다운로드
  • 백업 및 복원 작업
  • 가져오기 또는 내보내기 작업
  • 데이터 가져오기
  • 로컬 파일 처리
  • 네트워크를 통해 기기와 클라우드 간에 데이터 전송
대안

자세한 내용은 데이터 동기화 포그라운드 서비스 대안을 참고하세요.

Health

要在其清单中声明的前台服务类型
android:foregroundServiceType
health
在清单中声明的权限
FOREGROUND_SERVICE_HEALTH
要传递给 startForeground() 的常量
FOREGROUND_SERVICE_TYPE_HEALTH
运行时前提条件

必须至少满足以下其中一个条件:

注意BODY_SENSORS 运行时权限受使用时限制。因此,您无法创建在应用在后台运行时使用身体传感器的 health 前台服务,但存在一些例外情况。如需了解详情,请参阅有关启动需要运行时权限的前台服务的限制

说明

为健身类别的应用(例如锻炼追踪器)提供支持的所有长时间运行的用例。

위치

매니페스트에서 선언할 포그라운드 서비스 유형
android:foregroundServiceType
location
매니페스트에서 선언할 수 있는 권한
FOREGROUND_SERVICE_LOCATION
startForeground()에 전달할 상수
FOREGROUND_SERVICE_TYPE_LOCATION
런타임 기본 요건

사용자가 위치 서비스를 사용 설정해야 하며 앱에 다음 런타임 권한 중 하나 이상이 부여되어야 합니다.

참고: 사용자가 위치 서비스를 사용 설정하고 런타임 권한에 대한 액세스 권한을 부여했는지 확인하려면 PermissionChecker#checkSelfPermission()를 사용하세요.

참고: 위치 런타임 권한에는 사용 중 제한사항이 적용됩니다. 따라서 ACCESS_BACKGROUND_LOCATION 런타임 권한을 부여받지 않는 한 앱이 백그라운드에 있는 동안 location 포그라운드 서비스를 만들 수 없습니다. 자세한 내용은 사용 중 권한이 필요한 포그라운드 서비스 시작에 관한 제한사항을 참고하세요.

설명

탐색 및 위치 공유와 같이 위치 액세스가 필요한 장기 실행 사용 사례

대안

사용자가 특정 위치에 도달할 때 앱을 트리거해야 한다면 대신 지오펜싱 API를 사용하는 것이 좋습니다.

미디어

매니페스트에서 선언할 포그라운드 서비스 유형
android:foregroundServiceType
mediaPlayback
매니페스트에서 선언할 권한
FOREGROUND_SERVICE_MEDIA_PLAYBACK
startForeground()에 전달할 상수
FOREGROUND_SERVICE_TYPE_MEDIA_PLAYBACK
런타임 기본 요건
없음
설명
백그라운드에서 오디오 또는 동영상을 계속 재생합니다. Android TV에서 디지털 동영상 녹화 (DVR) 기능을 지원합니다.
대안
PIP 모드를 표시하는 경우에는 PIP 모드를 사용합니다.

미디어 프로젝션

要在其清单中声明的前台服务类型
android:foregroundServiceType
mediaProjection
在清单中声明的权限
FOREGROUND_SERVICE_MEDIA_PROJECTION
要传递给 startForeground() 的常量
FOREGROUND_SERVICE_TYPE_MEDIA_PROJECTION
运行时前提条件

在启动前台服务之前,调用 createScreenCaptureIntent() 方法。执行此操作会向用户显示权限通知;用户必须授予权限,您才能创建服务。

创建前台服务后,您可以调用 MediaProjectionManager.getMediaProjection()

说明

使用 MediaProjection API 将内容投影到非主要显示屏或外部设备。这些内容不一定是完全媒体内容。

替代方案

如需将媒体内容流式传输到其他设备,请使用 Google Cast SDK

마이크

要在其清单中声明的前台服务类型
android:foregroundServiceType
microphone
在清单中声明的权限
FOREGROUND_SERVICE_MICROPHONE
要传递给 startForeground() 的常量
FOREGROUND_SERVICE_TYPE_MICROPHONE
运行时前提条件

请求并获得 RECORD_AUDIO 运行时权限。

注意RECORD_AUDIO 运行时权限受使用时限制。因此,当您的应用位于后台时,您无法创建 microphone 前台服务,但存在一些例外情况。如需了解详情,请参阅有关启动需要运行时权限的前台服务的限制

说明

在后台继续捕获麦克风内容,例如录音器或通信应用。

전화 통화

매니페스트에서 선언할 포그라운드 서비스 유형
android:foregroundServiceType
phoneCall
매니페스트에서 선언할 권한
FOREGROUND_SERVICE_PHONE_CALL
startForeground()에 전달할 상수
FOREGROUND_SERVICE_TYPE_PHONE_CALL
런타임 기본 요건

다음 조건 중 하나 이상에 해당해야 합니다.

  • 앱이 매니페스트 파일에서 MANAGE_OWN_CALLS 권한을 선언했습니다.
  • 앱이 ROLE_DIALER 역할을 통해 기본 다이얼러 앱입니다.
설명

ConnectionService API를 사용하여 진행 중인 호출을 계속합니다.

대안

전화, 영상, VoIP 통화를 이용해야 한다면 android.telecom 라이브러리를 사용해 보세요.

CallScreeningService를 사용하여 통화를 선택해 보세요.

원격 메시지

매니페스트에서 선언할 포그라운드 서비스 유형
android:foregroundServiceType
remoteMessaging
매니페스트에서 선언할 권한
FOREGROUND_SERVICE_REMOTE_MESSAGING
startForeground()에 전달할 상수
FOREGROUND_SERVICE_TYPE_REMOTE_MESSAGING
런타임 기본 요건
없음
설명
문자 메시지를 한 기기에서 다른 기기로 전송합니다. 사용자가 기기를 전환할 때 사용자의 메시지 작업의 연속성을 지원합니다.

짧은 서비스

매니페스트에서 선언할 포그라운드 서비스 유형
android:foregroundServiceType
shortService
매니페스트에서 선언할 권한
없음
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:foregroundServiceType
specialUse
在清单中声明的权限
FOREGROUND_SERVICE_SPECIAL_USE
要传递给 startForeground() 的常量
FOREGROUND_SERVICE_TYPE_SPECIAL_USE
运行时前提条件
说明

涵盖其他前台服务类型未涵盖的所有有效前台服务用例。

除了声明 FOREGROUND_SERVICE_TYPE_SPECIAL_USE 前台服务类型之外,开发者还应在清单中声明用例。为此,他们会在 <service> 元素内指定 <property> 元素。当您在 Google Play 管理中心内提交应用时,我们会审核这些值和相应的用例。您提供的用例是自由形式的,您应确保提供足够的信息,让审核人员了解您为何需要使用 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:foregroundServiceType
systemExempted
매니페스트에서 선언할 권한
FOREGROUND_SERVICE_SYSTEM_EXEMPTED
startForeground()에 전달할 상수
FOREGROUND_SERVICE_TYPE_SYSTEM_EXEMPTED
런타임 기본 요건
없음
설명

포그라운드 서비스를 계속 사용하기 위해 시스템 애플리케이션 및 특정 시스템 통합을 위해 예약됩니다.

이 유형을 사용하려면 앱이 다음 기준 중 하나 이상을 충족해야 합니다.

포그라운드 서비스 유형 사용에 관한 Google Play 정책 시행

앱이 Android 14 이상을 타겟팅한다면 Play Console의 앱 콘텐츠 페이지 (정책 > 앱 콘텐츠)에서 앱의 포그라운드 서비스 유형을 선언해야 합니다. Play Console에서 포그라운드 서비스 유형을 선언하는 방법에 관한 자세한 내용은 포그라운드 서비스 및 전체 화면 인텐트 요구사항 이해를 참고하세요.