Ön plan hizmet türleri gereklidir

为了帮助开发者更有目的地定义面向用户的前台服务,Android 10 在 <service> 元素内引入了 android:foregroundServiceType 属性。

如果您的应用以 Android 14 为目标平台,则必须指定适当的前台服务类型。与以前的 Android 版本一样,可组合使用多个类型。下面列出了可供选择的前台服务类型:

如果应用中的用例与这些类型均不相关,强烈建议您迁移逻辑以使用 WorkManager用户发起的数据传输作业

Android 14 中新增了 health, remoteMessaging, shortService, specialUsesystemExempted 类型。

以下代码段提供了一个清单中的前台服务类型声明示例:

<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

Ön plan hizmet türlerini kullanmak için yeni izin bildirme

Android 14'ü hedefleyen uygulamaların bir ön plan hizmeti kullanması durumunda bu uygulamaların, Android 14'ün sunduğu ön plan hizmet türüne göre belirli bir izni beyan etmesi gerekir. Bu izinler, bu sayfadaki her ön plan hizmet türü için amaçlanan kullanım alanları ve yaptırımlar bölümünde yer alan "manifest dosyanızda beyan etmeniz gereken izin" etiketli bölümlerde görünür.

Tüm izinler normal izinler olarak tanımlanır ve varsayılan olarak verilir. Kullanıcılar bu izinleri iptal edemez.

Çalışma zamanında ön plan hizmet türünü dahil et

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

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

ServiceCompat.startForeground(0, notification, FOREGROUND_SERVICE_TYPE_LOCATION)

如果调用中未指定前台服务类型,则默认为类型 与清单中定义的值相关联如果您未指定服务 类型,系统就会抛出 MissingForegroundServiceTypeException

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

Sistem çalışma zamanı kontrolleri

Sistem, ön plan hizmeti türlerinin uygun şekilde kullanılıp kullanılmadığını kontrol eder ve uygulamanın uygun çalışma zamanı izinlerini istediğini veya gerekli API'leri kullandığını onaylar. Örneğin, sistem FOREGROUND_SERVICE_TYPE_LOCATION ön plan hizmet türünü kullanan uygulamaların ACCESS_COARSE_LOCATION veya ACCESS_FINE_LOCATION isteğinde bulunmasını bekler.

Bu, uygulamaların kullanıcıdan izin isterken ve ön plan hizmetlerini başlatırken çok spesifik bir işlem sırası izlemesi gerektiği anlamına gelir. İzinler, uygulama startForeground() yöntemini çağırmadan önce istenmeli ve verilmelidir. Ön plan hizmeti başlatıldıktan sonra uygun izinleri isteyen uygulamalar bu işlem sırasını değiştirmeli ve ön plan hizmetini başlatmadan önce izin istemelidir.

Platform yaptırımının ayrıntıları, bu sayfadaki her ön plan hizmet türü için amaçlanan kullanım alanları ve yaptırım bölümündeki "çalışma zamanı gereksinimleri" etiketli bölümlerde gösterilmektedir.

Her ön plan hizmet türü için amaçlanan kullanım alanları ve yaptırımlar

Belirli bir ön plan hizmet türünü kullanmak için manifest dosyanızda belirli bir izin beyan etmeniz, belirli çalışma zamanı gereksinimlerini karşılamanız ve uygulamanızın söz konusu tür için amaçlanan kullanım alanı gruplarından birini karşılaması gerekir. Aşağıdaki bölümlerde beyan etmeniz gereken izin, çalışma zamanı ön koşulları ve her tür için amaçlanan kullanım alanları açıklanmaktadır.

Kamera

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

请求并获得 CAMERA 运行时权限

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

说明

继续在后台访问摄像头,例如支持多任务的视频聊天应用。

Bağlı cihaz

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

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

说明

与需要蓝牙、NFC、IR、USB 或网络连接的外部设备进行互动。

替代方案

如果您的应用需要持续将数据传输到外部设备,请考虑改用配套设备管理器。使用配套设备在线状态 API 帮助您的应用在配套设备在范围内时保持运行。

如果您的应用需要扫描蓝牙设备,请考虑改用 Bluetooth Scanner API

Veri senkronizasyonu

Manifestte bildirilecek ön plan hizmeti türü
android:foregroundServiceType
dataSync
Manifest dosyanızda beyan etme izni
FOREGROUND_SERVICE_DATA_SYNC
startForeground() için sabit geçiş
FOREGROUND_SERVICE_TYPE_DATA_SYNC
Çalışma zamanı ön koşulları
Hiçbiri
Açıklama

Aşağıdakiler gibi veri aktarımı işlemleri:

  • Veri yükleme veya indirme
  • Yedekleme ve geri yükleme işlemleri
  • İçe veya dışa aktarma işlemleri
  • Verileri getir
  • Yerel dosya işleme
  • Ağ üzerinden cihaz ile bulut arasında veri aktarma
Alternatifler

Ayrıntılı bilgi için Veri senkronizasyonu ön plan hizmetlerine alternatifler bölümüne bakın.

Sağlık

Manifestte bildirilecek ön plan hizmeti türü
android:foregroundServiceType
health
Manifest dosyanızda beyan etme izni
FOREGROUND_SERVICE_HEALTH
startForeground() için sabit geçiş
FOREGROUND_SERVICE_TYPE_HEALTH
Çalışma zamanı ön koşulları

Aşağıdaki koşullardan en az biri doğru olmalıdır:

Not: BODY_SENSORS çalışma zamanı izni, kullanım sırasındaki kısıtlamalara tabidir. Bu nedenle, birkaç istisna dışında, uygulamanız arka plandayken vücut sensörlerini kullanan bir health ön plan hizmeti oluşturamazsınız. Daha fazla bilgi için Kullanım sırasında izin gerektiren ön plan hizmetlerinin başlatılmasıyla ilgili kısıtlamalar bölümüne bakın.

Açıklama

Fitness kategorisindeki uygulamaları destekleyen uzun süreli kullanım alanları (ör. egzersiz izleyiciler).

Konum

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

用户必须已启用位置信息服务,并且必须至少向应用授予以下运行时权限之一:

注意:如需检查用户是否已启用位置信息服务以及是否已授予运行时权限的访问权限,请使用 PermissionChecker#checkSelfPermission()

注意:位置信息运行时权限受使用时限制的约束。因此,当应用在后台运行时,您无法创建 location 前台服务,除非您已被授予 ACCESS_BACKGROUND_LOCATION 运行时权限。如需了解详情,请参阅对启动需要在使用时授予权限的前台服务的限制

说明

需要位置信息使用权的长时间运行的用例,例如导航和位置信息分享。

替代方案

如果您的应用需要在用户到达特定位置时触发,请考虑改用 Geofence API

Medya

Manifestte bildirilecek ön plan hizmeti türü
android:foregroundServiceType
mediaPlayback
Manifest dosyanızda beyan etme izni
FOREGROUND_SERVICE_MEDIA_PLAYBACK
startForeground() için sabit geçiş
FOREGROUND_SERVICE_TYPE_MEDIA_PLAYBACK
Çalışma zamanı ön koşulları
Hiçbiri
Açıklama
Ses veya video oynatmaya arka planda devam edin. Android TV'de Dijital Video Kayıt (DVR) işlevini destekleyin.
Alternatifler
Pencere içinde pencere gösteriyorsanız Pencere İçinde Pencere modunu kullanın.

Medya projeksiyonu

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

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

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

说明

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

替代方案

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

Mikrofon

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

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

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

说明

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

Sesli arama

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

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

  • 应用通过 ROLE_DIALER 角色成为默认拨号器应用。
说明

使用 ConnectionService API 继续当前通话。

替代方案

如果您需要拨打电话、视频或 VoIP 通话,请考虑使用 android.telecom 库。

不妨考虑使用 CallScreeningService 过滤来电。

Uzaktan mesajlaşma

Manifestte bildirilecek ön plan hizmeti türü
android:foregroundServiceType
remoteMessaging
Manifest dosyanızda beyan etme izni
FOREGROUND_SERVICE_REMOTE_MESSAGING
startForeground() için sabit geçiş
FOREGROUND_SERVICE_TYPE_REMOTE_MESSAGING
Çalışma zamanı ön koşulları
Hiçbiri
Açıklama
Kısa mesajları bir cihazdan diğerine aktarın. Cihaz değiştirdiğinde kullanıcıların mesajlaşma görevlerinin devam etmesine yardımcı olur.

Kısa servis

要在其清单中声明的前台服务类型
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 类型声明。不过,该服务仍必须遵守其他声明类型的前提条件。如需了解详情,请参阅前台服务文档

Özel kullanım

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

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

除了声明 FOREGROUND_SERVICE_TYPE_SPECIAL_USE 前台服务类型之外,开发者还应在清单中声明用例。为此,他们会在 <service> 元素内指定 <property> 元素。这些值和相应的应用场景 。用途 您提供的案例均为自由形式,因此,您应确保提供足够的 相关信息,让审核人员了解您为何需要使用 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>

Sistemden muaf

Manifest dosyasında tanımlanacak ön plan hizmet türü
android:foregroundServiceType
systemExempted
Manifest'inizde beyan etme izni
FOREGROUND_SERVICE_SYSTEM_EXEMPTED
startForeground() noktasına ulaşılmasına kalan süre
FOREGROUND_SERVICE_TYPE_SYSTEM_EXEMPTED
Çalışma zamanı ön koşulları
Yok
Açıklama

Sistem uygulamaları ve spesifik sistem entegrasyonları için ayrılmıştır. ön plan hizmetlerini kullanmaya devam edebilir.

Bu türü kullanmak için uygulamanın aşağıdaki ölçütlerden en az birini karşılaması gerekir:

  • Cihaz demo modunda
  • Uygulama bir Cihaz Sahibidir
  • Uygulama bir Profiler Sahibidir
  • ROLE_EMERGENCY rolüne sahip Güvenlik Uygulamaları
  • Cihaz Yöneticisi uygulamaları
  • SCHEDULE_EXACT_ALARM veya USE_EXACT_ALARM iznine sahip ve kullanıcıları Alarmları arka planda devam ettirmek için Ön Plan Hizmeti, yalnızca dokunma teknolojisiyle çalışan alarmlar da dahil.
  • VPN uygulamaları (Ayarlar > Ağ ve İnternet > VPN kullanılarak yapılandırılır)

    Aksi takdirde, bu türün bildirilmesi sistemin ForegroundServiceTypeNotAllowedException

Ön plan hizmeti türlerini kullanmayla ilgili Google Play politika yaptırımı

Uygulamanız Android 14 veya sonraki sürümleri hedefliyorsa Play Console'un uygulama içeriği sayfasında (Politika > Uygulama içeriği) uygulamanızın ön plan hizmet türlerini beyan etmeniz gerekir. Play Console'da ön plan hizmet türlerinizi nasıl beyan edeceğiniz hakkında daha fazla bilgi için Ön plan hizmetini ve tam ekran intent şartlarını anlama bölümüne bakın.