前景服務說明文件說明 Android 前景服務的目前行為。無論應用程式是否指定最新版 Android,這份文件都會提供適用於大多數應用程式的最佳做法指南。
本頁說明前景服務的部分最新重要變更,以及對未指定最新版 Android 平台的應用程式所造成的影響。在許多情況下,針對較低 API 級別的應用程式為選用的最佳做法,但針對較高 API 級別的應用程式則為必做。
Android 16 (API 級別 36)
以下變更適用於在 Android 16 以上版本執行的應用程式,無論其指定的 API 級別為何:
從前景服務啟動的背景工作現在必須遵守各自的執行階段配額。這包括直接透過
JobScheduler
排定的作業,以及由其他程式庫 (例如 WorkManager 或DownloadManager
) 建立的作業。如要回應使用者動作並轉移資料,建議您使用使用者啟動的資料轉移工作。這些工作不受一般工作配額的限制。
Android 15 (API 級別 35)
以下規定適用於指定 API 級別 35 以上版本的應用程式:
dataSync
前景服務的執行時間長度有新的限制。如要瞭解這些限制,請參閱「前景服務逾時行為」。同樣的限制也適用於 (Android 15 新增)mediaProcessing
前景服務類型。BOOT_COMPLETED
前景服務不再允許啟動特定前景服務。- 擁有
SYSTEM_ALERT_WINDOW
權限的應用程式,只有在目前有可見的疊加層視窗 (或符合其他從背景啟動限制的豁免條件) 時,才能從背景啟動前景服務。先前,這些應用程式的豁免條款較為廣泛。
Android 14 (API 級別 34)
以下規定適用於指定 API 級別 34 以上級別的應用程式:
- 您必須聲明所有前景服務,並附上服務類型。
- 應用程式必須根據前景服務要執行的工作類型,要求適當的權限類型。每個前景服務類型都有對應的權限類型。舉例來說,如果應用程式啟動使用攝影機的前景服務,您必須同時要求
FOREGROUND_SERVICE
和FOREGROUND_SERVICE_CAMERA
權限。如果應用程式指定的 API 級別為 34 以上,但未要求適當的特定權限,系統會擲回SecurityException
。
Android 12 (API 級別 31)
以下規定適用於指定 API 級別 31 以上版本的應用程式:
- 應用程式在背景執行時,不得啟動前景服務,但有少數例外情況。如需進一步瞭解這項規則的例外狀況,請參閱「從背景啟動前景服務的限制」。
Android 11 (API 級別 30)
以下規定適用於指定 API 級別 30 以上版本的應用程式:
- 如果應用程式的前景服務使用相機或麥克風,則應用程式必須分別使用
camera
或microphone
服務類型宣告服務。
Android 10 (API 級別 29)
以下規定適用於鎖定 API 級別 29 以上版本的應用程式:
Android 9 (API 級別 28)
Android 9 推出 FOREGROUND_SERVICE
權限。在 Android 9 上執行且使用前景服務的應用程式,必須具備該權限。
如果指定 API 級別 28 以上版本為目標版本的應用程式嘗試建立前景服務,但未要求 FOREGROUND_SERVICE
權限,系統就會擲回 SecurityException
。