Để giúp nhà phát triển thể hiện rõ ý định khi xác định dịch vụ trên nền trước dành cho người dùng, Android 10 đã cho ra mắt thuộc tính android:foregroundServiceType trong phần tử <service>.
Nếu ứng dụng của bạn nhắm đến Android 14, thì ứng dụng đó phải chỉ định các kiểu dịch vụ thích hợp trên nền trước. Như trong các phiên bản Android trước đây, bạn có thể kết hợp nhiều kiểu. Danh sách này cho thấy các kiểu dịch vụ trên nền trước để bạn lựa chọn:
cameraconnectedDevicedataSynchealthlocationmediaPlaybackmediaProjectionmicrophonephoneCallremoteMessagingshortServicespecialUsesystemExempted
Nếu một trường hợp sử dụng trong ứng dụng không liên quan đến bất cứ kiểu nào trong số này, bạn nên di chuyển logic để sử dụng WorkManager hoặc công việc chuyển dữ liệu do người dùng khởi tạo.
health, remoteMessaging, shortService, specialUse và systemExempted là các kiểu mới trong Android 14.
Đoạn mã sau đây cho thấy ví dụ về cách khai báo kiểu dịch vụ trên nền trước trong tệp kê khai:
<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>
Nếu một ứng dụng nhắm đến Android 14 không xác định kiểu cho một dịch vụ nhất định trong tệp kê khai, thì hệ thống sẽ tăng MissingForegroundServiceTypeException khi gọi startForeground() cho dịch vụ đó.
Khai báo quyền mới để sử dụng các loại dịch vụ trên nền trước
Nếu ứng dụng nhắm đến Android 14 và có sử dụng dịch vụ trên nền trước, thì ứng dụng đó phải khai báo một quyền cụ thể, dựa trên loại dịch vụ trên nền trước mà Android 14 ra mắt. Các quyền này xuất hiện trong những phần có nhãn "quyền mà bạn phải khai báo trong tệp kê khai" trong phần các trường hợp sử dụng dự kiến và biện pháp thực thi cho từng loại dịch vụ trên nền trước trên trang này.
Tất cả quyền đó được xác định là quyền thông thường và được cấp theo mặc định. Người dùng không thể thu hồi các quyền này.
Cung cấp loại dịch vụ trên nền trước trong thời gian chạy
Phương pháp hay nhất cho các ứng dụng có bắt đầu dịch vụ trên nền trước là sử dụng phiên bản ServiceCompat của startForeground() (có trong androidx-core 1.12 trở lên), trong đó bạn truyền một số nguyên bitwise của các kiểu dịch vụ trên nền trước. Bạn có thể chọn truyền một hoặc nhiều giá trị tương ứng với từng kiểu.
Thường thì bạn chỉ nên khai báo các kiểu cần thiết cho một trường hợp sử dụng cụ thể. Điều này giúp bạn dễ dàng đáp ứng các kỳ vọng của hệ thống đối với từng loại dịch vụ trên nền trước. Trong trường hợp sử dụng nhiều kiểu để bắt đầu dịch vụ trên nền trước, thì dịch vụ trên nền trước đó phải tuân thủ các yêu cầu thực thi trên nền tảng của tất cả kiểu.
ServiceCompat.startForeground(0, notification, FOREGROUND_SERVICE_TYPE_LOCATION)
Nếu kiểu dịch vụ trên nền trước không được chỉ định trong lệnh gọi, thì kiểu này sẽ mặc định là các giá trị được xác định trong tệp kê khai. Nếu bạn không chỉ định loại dịch vụ trong tệp kê khai, hệ thống sẽ gửi MissingForegroundServiceTypeException.
Nếu dịch vụ trên nền trước cần các quyền mới sau khi bạn khởi chạy, bạn nên gọi lại startForeground() và thêm các loại dịch vụ mới. Ví dụ: giả sử một ứng dụng thể dục chạy một dịch vụ theo dõi chạy bộ luôn cần thông tin location, nhưng có thể cần hoặc không cần quyền media. Bạn cần khai báo cả location và mediaPlayback trong tệp kê khai. Nếu người dùng bắt đầu chạy và chỉ muốn theo dõi vị trí của họ, thì ứng dụng của bạn sẽ gọi startForeground() và chỉ truyền loại dịch vụ location. Sau đó, nếu người dùng muốn bắt đầu phát âm thanh, hãy gọi lại startForeground() và truyền location|mediaPlayback.
Kiểm tra thời gian chạy của hệ thống
Hệ thống kiểm tra việc sử dụng đúng cách các loại dịch vụ trên nền trước và xác nhận rằng ứng dụng đã yêu cầu quyền thời gian chạy thích hợp hoặc sử dụng API đúng yêu cầu.
Ví dụ: hệ thống yêu cầu các ứng dụng dùng loại dịch vụ trên nền trước FOREGROUND_SERVICE_TYPE_LOCATION để yêu cầu ACCESS_COARSE_LOCATION hoặc ACCESS_FINE_LOCATION.
Tức là ứng dụng phải tuân theo một thứ tự hoạt động rất cụ thể khi yêu cầu người dùng cấp quyền và bắt đầu các dịch vụ trên nền trước. Các quyền phải được yêu cầu và được cấp trước khi ứng dụng cố gắng gọi startForeground(). Các ứng dụng yêu cầu quyền thích hợp sau khi bắt đầu dịch vụ trên nền trước phải thay đổi thứ tự hoạt động này và yêu cầu quyền trước khi bắt đầu dịch vụ trên nền trước.
Thông tin cụ thể về việc thực thi của nền tảng sẽ xuất hiện trong các phần có nhãn "yêu cầu về thời gian chạy" trong phần Các trường hợp sử dụng dự kiến và việc thực thi từng loại dịch vụ trên nền trước trên trang này.
Trường hợp sử dụng dự kiến và biện pháp thực thi đối với từng loại dịch vụ trên nền trước
Để sử dụng một kiểu dịch vụ trên nền trước nhất định, bạn phải khai báo một quyền cụ thể trong tệp kê khai, bạn phải đáp ứng các yêu cầu cụ thể về thời gian chạy, cũng như ứng dụng của bạn phải đáp ứng một trong các nhóm trường hợp sử dụng dự kiến cho kiểu đó. Các phần sau giải thích quyền bạn phải khai báo, các điều kiện tiên quyết về thời gian chạy và các trường hợp sử dụng dự kiến của từng kiểu.
Máy ảnh
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai trong
android:foregroundServiceType camera- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_CAMERA- Hằng số để truyền đến
startForeground() FOREGROUND_SERVICE_TYPE_CAMERA- Điều kiện tiên quyết về thời gian chạy
Yêu cầu và được cấp quyền khi bắt đầu chạy
CAMERALưu ý: Quyền khi bắt đầu chạy
CAMERAphải tuân theo các quy định hạn chế khi đang sử dụng. Vì lý do này, bạn không thể tạo dịch vụ trên nền trướccamerakhi ứng dụng đang chạy ở chế độ nền, ngoại trừ một số trường hợp ngoại lệ. Để biết thêm thông tin, hãy xem phần Hạn chế khi khởi động các dịch vụ trên nền trước cần quyền khi đang sử dụng.- Mô tả
Tiếp tục truy cập vào máy ảnh ở chế độ nền, chẳng hạn như các ứng dụng trò chuyện video cho phép thực thi đa nhiệm.
Thiết bị đã kết nối
- Foreground service type to declare in manifest under
android:foregroundServiceTypeconnectedDevice- Permission to declare in your manifest
FOREGROUND_SERVICE_CONNECTED_DEVICE- Constant to pass to
startForeground() FOREGROUND_SERVICE_TYPE_CONNECTED_DEVICE- Runtime prerequisites
At least one of the following conditions must be true:
Declare at least one of the following permissions in your manifest:
Request and be granted at least one of the following runtime permissions:
- Description
Interactions with external devices that require a Bluetooth, NFC, IR, USB, or network connection.
- Alternatives
If your app needs to do continuous data transfer to an external device, consider using the companion device manager instead. Use the companion device presence API to help your app stay running while the companion device is in range.
If your app needs to scan for bluetooth devices, consider using the Bluetooth scan API instead.
Đồng bộ hoá dữ liệu
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai theo
android:foregroundServiceTypedataSync- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_DATA_SYNC- Hằng số để truyền đến
startForeground() FOREGROUND_SERVICE_TYPE_DATA_SYNC- Điều kiện tiên quyết về thời gian chạy
- Không có
- Nội dung mô tả
Các hoạt động chuyển dữ liệu, chẳng hạn như:
- Tải dữ liệu lên hoặc tải dữ liệu xuống
- Hoạt động sao lưu và khôi phục
- Hoạt động nhập hoặc xuất dữ liệu
- Tìm nạp dữ liệu
- Xử lý tệp cục bộ
- Chuyển dữ liệu giữa thiết bị và đám mây qua mạng
- Lựa chọn thay thế
Hãy xem phần Các giải pháp thay thế cho dịch vụ đồng bộ hoá dữ liệu trên nền trước để biết thông tin chi tiết.
Sức khoẻ
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai theo
android:foregroundServiceTypehealth- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_HEALTH- Hằng số để truyền đến
startForeground() FOREGROUND_SERVICE_TYPE_HEALTH- Điều kiện tiên quyết về thời gian chạy
Ít nhất một trong các điều kiện sau phải đúng:
Khai báo quyền
HIGH_SAMPLING_RATE_SENSORStrong tệp kê khai.Yêu cầu và được cấp ít nhất một trong các quyền khi bắt đầu chạy sau đây:
BODY_SENSORStrên API cấp 35 trở xuốngREAD_HEART_RATEREAD_SKIN_TEMPERATUREREAD_OXYGEN_SATURATIONACTIVITY_RECOGNITION
Lưu ý: Quyền khi bắt đầu chạy ĐỌC dựa trên cảm biến và
BODY_SENSORSphải tuân thủ các hạn chế khi đang sử dụng. Vì lý do này, bạn không thể tạo một dịch vụ trên nền trướchealthsử dụng cảm biến cơ thể trong khi ứng dụng của bạn đang chạy ở chế độ nền, trừ phi bạn đã được cấp quyềnBODY_SENSORS_BACKGROUND(API cấp 33 đến 35) hoặcREAD_HEALTH_DATA_IN_BACKGROUND(API cấp 36 trở lên). Để biết thêm thông tin, hãy xem phần Hạn chế khi khởi động các dịch vụ trên nền trước cần quyền khi đang sử dụng.- Mô tả
Trường hợp sử dụng lâu dài bất kỳ để hỗ trợ các ứng dụng trong danh mục thể dục (ví dụ: trình theo dõi bài tập thể dục).
Vị trí
- Foreground service type to declare in manifest under
android:foregroundServiceTypelocation- Permission to declare in your manifest
FOREGROUND_SERVICE_LOCATION- Constant to pass to
startForeground() FOREGROUND_SERVICE_TYPE_LOCATION- Runtime prerequisites
The user must have enabled location services and the app must be granted at least one of the following runtime permissions:
Note: In order to check that the user has enabled location services as well as granted access to the runtime permissions, use
PermissionChecker#checkSelfPermission()Note: The location runtime permissions are subject to while-in-use restrictions. For this reason, you cannot create a
locationforeground service while your app is in the background, unless you've been granted theACCESS_BACKGROUND_LOCATIONruntime permission. For more information, see Restrictions on starting foreground services that need while-in-use permissions.- Description
Long-running use cases that require location access, such as navigation and location sharing.
- Alternatives
If your app needs to be triggered when the user reaches specific locations, consider using the geofence API instead.
Nội dung nghe nhìn
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai theo
android:foregroundServiceTypemediaPlayback- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_MEDIA_PLAYBACK- Hằng số để truyền đến
startForeground() FOREGROUND_SERVICE_TYPE_MEDIA_PLAYBACK- Điều kiện tiên quyết về thời gian chạy
- Không có
- Nội dung mô tả
- Tiếp tục phát âm thanh hoặc video ở chế độ nền. Hỗ trợ chức năng Quay video kỹ thuật số (DVR) trên Android TV.
- Lựa chọn thay thế
- Nếu bạn đang hiển thị video hình trong hình, hãy sử dụng chế độ Hình trong hình.
Chiếu nội dung nghe nhìn
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai theo
android:foregroundServiceTypemediaProjection- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_MEDIA_PROJECTION- Hằng số để truyền đến
startForeground() FOREGROUND_SERVICE_TYPE_MEDIA_PROJECTION- Điều kiện tiên quyết về thời gian chạy
Gọi phương thức
createScreenCaptureIntent()trước khi bắt đầu dịch vụ trên nền trước. Thao tác này sẽ hiển thị thông báo cấp quyền cho người dùng; người dùng phải cấp quyền thì bạn mới có thể tạo dịch vụ.Sau khi tạo dịch vụ trên nền trước, bạn có thể gọi
MediaProjectionManager.getMediaProjection().- Mô tả
Chiếu nội dung tới màn hình phụ hoặc thiết bị bên ngoài bằng các API
MediaProjection. Nội dung này không nhất thiết chỉ là nội dung đa phương tiện.- Lựa chọn thay thế
Để truyền trực tuyến nội dung nghe nhìn sang một thiết bị khác, hãy sử dụng SDK Google Cast.
Micrô
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai theo
android:foregroundServiceTypemicrophone- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_MICROPHONE- Hằng số để truyền đến
startForeground() FOREGROUND_SERVICE_TYPE_MICROPHONE- Điều kiện tiên quyết về thời gian chạy
Yêu cầu và được cấp quyền khi bắt đầu chạy
RECORD_AUDIO.Lưu ý: Quyền khi bắt đầu chạy
RECORD_AUDIOphải tuân theo các quy định hạn chế khi đang sử dụng. Vì lý do này, bạn không thể tạo dịch vụ trên nền trướcmicrophonekhi ứng dụng đang chạy ở chế độ nền, ngoại trừ một số trường hợp ngoại lệ. Để biết thêm thông tin, hãy xem phần Hạn chế khi khởi động các dịch vụ trên nền trước cần quyền khi đang sử dụng.- Mô tả
Tiếp tục ghi âm qua micrô ở chế độ nền, chẳng hạn như trình ghi âm giọng nói hoặc ứng dụng giao tiếp.
Cuộc gọi điện thoại
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai theo
android:foregroundServiceTypephoneCall- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_PHONE_CALL- Hằng số để truyền đến
startForeground() FOREGROUND_SERVICE_TYPE_PHONE_CALL- Điều kiện tiên quyết về thời gian chạy
Ít nhất một trong các điều kiện sau phải đúng:
- Ứng dụng đã khai báo quyền
MANAGE_OWN_CALLStrong tệp kê khai.
- Ứng dụng đã khai báo quyền
- Ứng dụng là ứng dụng quay số mặc định thông qua vai trò
ROLE_DIALER.
- Ứng dụng là ứng dụng quay số mặc định thông qua vai trò
- Mô tả
Tiếp tục cuộc gọi đang diễn ra bằng các API
ConnectionService.- Lựa chọn thay thế
Nếu bạn cần thực hiện cuộc gọi điện thoại, video hoặc VoIP, hãy cân nhắc sử dụng thư viện
android.telecom.Cân nhắc sử dụng
CallScreeningServiceđể sàng lọc cuộc gọi.
Nhắn tin từ xa
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai theo
android:foregroundServiceTyperemoteMessaging- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_REMOTE_MESSAGING- Hằng số để truyền đến
startForeground() FOREGROUND_SERVICE_TYPE_REMOTE_MESSAGING- Điều kiện tiên quyết về thời gian chạy
- Không có
- Nội dung mô tả
- Chuyển tin nhắn văn bản từ thiết bị này sang thiết bị khác. Hỗ trợ người dùng nhắn tin liên tục khi họ chuyển đổi thiết bị.
Dịch vụ ngắn
- Foreground service type to declare in manifest under
android:foregroundServiceTypeshortService- Permission to declare in your manifest
- None
- Constant to pass to
startForeground() FOREGROUND_SERVICE_TYPE_SHORT_SERVICE- Runtime prerequisites
- None
- Description
Quickly finish critical work that cannot be interrupted or postponed.
This type has some unique characteristics:
- Can only run for a short period of time (about 3 minutes).
- No support for sticky foreground services.
- Cannot start other foreground services.
- Doesn't require a type-specific permission, though it still
requires the
FOREGROUND_SERVICEpermission. - A
shortServicecan only change to another service type if the app is currently eligible to start a new foreground service. - A foreground service can change its type to
shortServiceat any time, at which point the timeout period begins.
The timeout for shortService begins from the moment that
Service.startForeground()is called. The app is expected to callService.stopSelf()orService.stopForeground()before the timeout occurs. Otherwise, the newService.onTimeout()is called, giving apps a brief opportunity to callstopSelf()orstopForeground()to stop their service.A short time after
Service.onTimeout()is called, the app enters a cached state and is no longer considered to be in the foreground, unless the user is actively interacting with the app. A short time after the app is cached and the service has not stopped, the app receives an ANR. The ANR message mentionsFOREGROUND_SERVICE_TYPE_SHORT_SERVICE. For these reasons, it's considered best practice to implement theService.onTimeout()callback.The
Service.onTimeout()callback doesn't exist on Android 13 and lower. If the same service runs on such devices, it doesn't receive a timeout, nor does it ANR. Make sure that your service stops as soon as it finishes the processing task, even if it hasn't received theService.onTimeout()callback yet.It's important to note that if the timeout of the
shortServiceis not respected, the app will ANR even if it has other valid foreground services or other app lifecycle processes running.If an app is visible to the user or satisfies one of the exemptions that allow foreground services to be started from the background, calling
Service.StartForeground()again with theFOREGROUND_SERVICE_TYPE_SHORT_SERVICEparameter extends the timeout by another 3 minutes. If the app isn't visible to the user and doesn't satisfy one of the exemptions, any attempt to start another foreground service, regardless of type, causes aForegroundServiceStartNotAllowedException.If a user disables battery optimization for your app, it's still affected by the timeout of shortService FGS.
If you start a foreground service that includes the
shortServicetype and another foreground service type, the system ignores theshortServicetype declaration. However, the service must still adhere to the prerequisites of the other declared types. For more information, see the Foreground services documentation.
Cách sử dụng đặc biệt
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai trong
android:foregroundServiceTypespecialUse- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_SPECIAL_USE- Hằng số để truyền đến
startForeground() FOREGROUND_SERVICE_TYPE_SPECIAL_USE- Điều kiện tiên quyết về thời gian chạy
- Không có
- Nội dung mô tả
Bao gồm mọi trường hợp sử dụng dịch vụ trên nền trước hợp lệ không thuộc các loại dịch vụ trên nền trước khác.
Ngoài việc khai báo loại dịch vụ trên nền trước
FOREGROUND_SERVICE_TYPE_SPECIAL_USE, nhà phát triển nên khai báo các trường hợp sử dụng trong tệp kê khai. Để làm vậy, họ cần chỉ định phần tử<property>trong phần tử<service>. Các giá trị này và trường hợp sử dụng tương ứng sẽ được xem xét khi bạn gửi ứng dụng trong Google Play Console. Việc sử dụng yêu cầu của bạn là theo mẫu tuỳ ý và bạn cần đảm bảo cung cấp đủ để cho nhân viên đánh giá biết lý do bạn cần sử dụngspecialUseloại.<service android:name="fooService" android:foregroundServiceType="specialUse"> <property android:name="android.app.PROPERTY_SPECIAL_USE_FGS_SUBTYPE" android:value="explanation_for_special_use"/> </service>
Được miễn trừ hệ thống
- Foreground service type to declare in manifest under
android:foregroundServiceTypesystemExempted- Permission to declare in your manifest
FOREGROUND_SERVICE_SYSTEM_EXEMPTED- Constant to pass to
startForeground() FOREGROUND_SERVICE_TYPE_SYSTEM_EXEMPTED- Runtime prerequisites
- None
- Description
Reserved for system applications and specific system integrations, to continue to use foreground services.
To use this type, an app must meet at least one of the following criteria:
- Device is in demo mode state
- App is a Device Owner
- App is a Profiler Owner
- Safety Apps that have the
ROLE_EMERGENCYrole - Device Admin apps
- Apps holding
SCHEDULE_EXACT_ALARMorUSE_EXACT_ALARMpermission and are using Foreground Service to continue alarms in the background, including haptics-only alarms. VPN apps (configured using Settings > Network & Internet > VPN)
Otherwise, declaring this type causes the system to throw a
ForegroundServiceTypeNotAllowedException.
Phương thức thực thi chính sách của Google Play đối với việc sử dụng các loại dịch vụ trên nền trước
Nếu ứng dụng của bạn nhắm đến Android 14 trở lên, bạn cần khai báo các loại dịch vụ trên nền trước của ứng dụng trên trang nội dung ứng dụng của Play Console (Chính sách > Nội dung ứng dụng). Để biết thêm thông tin về cách khai báo các loại dịch vụ trên nền trước trong Play Console, hãy xem bài viết Tìm hiểu các yêu cầu khi sử dụng ý định truy cập chế độ toàn màn hình và dịch vụ trên nền trước.