Tài liệu về dịch vụ trên nền trước mô tả hành vi hiện tại của các dịch vụ trên nền trước của Android. Tài liệu này đưa ra hướng dẫn về các phương pháp hay nhất cho hầu hết các ứng dụng, bất kể ứng dụng đó có nhắm đến phiên bản Android mới nhất hay không.
Trang này mô tả một số thay đổi quan trọng gần đây nhất đối với các dịch vụ trên nền trước và những tác động đối với các ứng dụng không nhắm đến phiên bản mới nhất của nền tảng Android. Trong nhiều trường hợp, các phương pháp hay nhất không bắt buộc đối với ứng dụng nhắm đến API cấp thấp hơn sẽ trở thành bắt buộc đối với ứng dụng nhắm đến API cấp cao hơn.
Android 16 (API cấp 36)
Những thay đổi sau đây áp dụng cho các ứng dụng chạy trên Android 16 trở lên, bất kể ứng dụng đó nhắm đến cấp độ API nào:
Các tác vụ trong nền được bắt đầu từ một dịch vụ trên nền trước hiện phải tuân thủ hạn mức thời gian chạy tương ứng. Điều này bao gồm cả những công việc được lên lịch trực tiếp bằng
JobScheduler
, cũng như những công việc do các thư viện khác tạo ra, chẳng hạn như WorkManager hoặcDownloadManager
.Để chuyển dữ liệu theo hành động của người dùng, hãy cân nhắc sử dụng công việc chuyển dữ liệu do người dùng khởi tạo. Những công việc này được miễn hạn ngạch công việc thông thường.
Android 15 (API cấp 35)
Các yêu cầu sau đây áp dụng cho những ứng dụng nhắm đến API cấp 35 trở lên:
- Có những hạn chế mới về thời gian chạy của dịch vụ trên nền trước
dataSync
. Các hạn chế này được mô tả trong phần Hành vi hết thời gian chờ của dịch vụ trên nền trước. Các hạn chế tương tự cũng áp dụng cho loại dịch vụ trên nền trướcmediaProcessing
(mới trong Android 15). BOOT_COMPLETED
Các dịch vụ trên nền trước không còn được phép khởi chạy một số dịch vụ trên nền trước nhất định.- Những ứng dụng có quyền
SYSTEM_ALERT_WINDOW
chỉ được phép khởi chạy các dịch vụ trên nền trước từ chế độ nền nếu hiện có một cửa sổ lớp phủ hiển thị (hoặc nếu đáp ứng một trong các trường hợp miễn trừ khác đối với các hạn chế khi khởi chạy ở chế độ nền). Trước đây, phạm vi miễn trừ cho những ứng dụng đó rộng hơn.
Android 14 (API cấp 34)
Các yêu cầu sau đây áp dụng cho những ứng dụng nhắm đến API cấp 34 trở lên:
- Bạn phải khai báo tất cả các dịch vụ trên nền trước cùng với các loại dịch vụ của chúng.
- Ứng dụng phải yêu cầu loại quyền thích hợp cho loại công việc mà dịch vụ trên nền trước sẽ thực hiện. Mỗi kiểu dịch vụ trên nền trước đều có một kiểu quyền tương ứng. Ví dụ: nếu một ứng dụng khởi chạy một dịch vụ trên nền trước dùng camera, bạn phải yêu cầu cả quyền
FOREGROUND_SERVICE
vàFOREGROUND_SERVICE_CAMERA
. Nếu một ứng dụng nhắm đến API cấp 34 trở lên và không yêu cầu quyền cụ thể thích hợp, thì hệ thống sẽ gửi mộtSecurityException
.
Android 12 (API cấp 31)
Các yêu cầu sau đây áp dụng cho những ứng dụng nhắm đến API cấp 31 trở lên:
- Ứng dụng không được phép chạy các dịch vụ trên nền trước khi đang chạy ở chế độ nền, ngoại trừ một số trường hợp cụ thể. Để biết thêm thông tin và thông tin về các trường hợp ngoại lệ đối với quy tắc này, hãy xem bài viết Các hạn chế khi khởi động một dịch vụ trên nền trước từ nền.
Android 11 (API cấp 30)
Các yêu cầu sau đây áp dụng cho những ứng dụng nhắm đến API cấp 30 trở lên:
- Nếu các dịch vụ trên nền trước của một ứng dụng sử dụng camera hoặc micrô, thì ứng dụng đó phải khai báo dịch vụ bằng loại dịch vụ
camera
hoặcmicrophone
tương ứng.
Android 10 (API cấp 29)
Các yêu cầu sau đây áp dụng cho những ứng dụng nhắm đến API cấp 29 trở lên:
- Nếu các dịch vụ trên nền trước của một ứng dụng sử dụng thông tin vị trí, thì ứng dụng đó phải khai báo dịch vụ bằng loại dịch vụ
location
.
Android 9 (API cấp 28)
Android 9 giới thiệu quyền FOREGROUND_SERVICE
. Những ứng dụng chạy trên Android 9 và sử dụng dịch vụ trên nền trước phải có quyền đó.
Nếu một ứng dụng nhắm đến API cấp 28 trở lên cố gắng tạo một dịch vụ trên nền trước mà không yêu cầu quyền FOREGROUND_SERVICE
, thì hệ thống sẽ gửi một SecurityException
.