Limitazioni relative all'avvio di un servizio in primo piano dal background

Le app che hanno come target Android 12 (livello API 31) o versioni successive non possono avviare servizi in primo piano mentre l'app è in esecuzione in background, ad eccezione di alcuni casi speciali. Se un'app tenta di avviare un servizio in primo piano mentre è in esecuzione in background e il servizio in primo piano non soddisfa uno dei casi eccezionali, il sistema genera un ForegroundServiceStartNotAllowedException.

Inoltre, se un'app vuole avviare un servizio in primo piano che richiede autorizzazioni durante l'utilizzo (ad esempio autorizzazioni per il sensore di movimento, la fotocamera, il microfono o la posizione), non può crearlo mentre è in background, anche se rientra in una delle esenzioni dalle limitazioni di avvio in background. Il motivo è spiegato nella sezione Limitazioni all'avvio di servizi in primo piano che richiedono autorizzazioni durante l'utilizzo.

Esenzioni dalle limitazioni relative all'avvio in background

Nelle seguenti situazioni, la tua app può avviare servizi in primo piano anche mentre è in esecuzione in background:

Limitazioni per l'avvio di servizi in primo piano che richiedono autorizzazioni durante l'utilizzo

Su Android 14 (livello API 34) o versioni successive, devi tenere conto di situazioni speciali se avvii un servizio in primo piano che richiede autorizzazioni durante l'utilizzo.

Se la tua app ha come target Android 14 o versioni successive, il sistema operativo verifica quando crei un servizio in primo piano per assicurarsi che l'app disponga di tutte le autorizzazioni appropriate per quel tipo di servizio. Ad esempio, quando crei un servizio in primo piano di tipo microfono, il sistema operativo verifica che la tua app disponga attualmente dell'autorizzazione RECORD_AUDIO. Se non disponi di questa autorizzazione, il sistema genera un messaggio di errore SecurityException.

Per le autorizzazioni durante l'uso, questo causa un potenziale problema. Se la tua app dispone di un'autorizzazione di accesso durante l'uso, questa autorizzazione è disponibile solo quando l'app è in primo piano. Ciò significa che se la tua app è in background e tenta di creare un servizio in primo piano di tipo fotocamera, posizione o microfono, il sistema rileva che l'app non dispone attualmente delle autorizzazioni richieste e genera un SecurityException.

Analogamente, se la tua app è in background e crea un servizio per la salute che richiede l'autorizzazione BODY_SENSORS, l'app non la possiede al momento e il sistema genera un'eccezione. (Questo non si applica se si tratta di un servizio sanitario che richiede autorizzazioni diverse, come ACTIVITY_RECOGNITION.) La chiamata a PermissionChecker.checkSelfPermission() non impedisce questo problema. Se la tua app dispone di un'autorizzazione di utilizzo e chiama checkSelfPermission() per verificare se dispone di questa autorizzazione, il metodo restituisce PERMISSION_GRANTED anche se l'app è in background. Quando il metodo restituisce PERMISSION_GRANTED, significa che "la tua app dispone di questa autorizzazione durante l'uso".

Per questo motivo, se il servizio in primo piano ha bisogno di un'autorizzazione durante l'uso, devi chiamare Context.startForegroundService() o Context.bindService() mentre la tua app ha un'attività visibile, a meno che il servizio non rientri in una delle esenzioni definite.

Esenzioni dalle limitazioni relative alle autorizzazioni in uso

In alcuni casi, anche se un servizio in primo piano viene avviato mentre l'app viene eseguita in background, può comunque accedere alle informazioni su posizione, fotocamera e microfono mentre l'app viene eseguita in primo piano ("durante l'uso").

Nelle stesse situazioni, se il servizio dichiara un tipo di servizio in primo piano di location e viene avviato da un'app che dispone dell'autorizzazione ACCESS_BACKGROUND_LOCATION, questo servizio può accedere alle informazioni sulla posizione in qualsiasi momento, anche quando l'app viene eseguita in background.

Il seguente elenco contiene queste situazioni:

  • Un componente di sistema avvia il servizio.
  • Il servizio inizia interagendo con i widget delle app.
  • Il servizio inizia interagendo con una notifica.
  • Il servizio inizia come PendingIntent inviato da un'altra app visibile.
  • Il servizio viene avviato da un'app che è un controller dei criteri dei dispositivi che viene eseguito in modalità Proprietario del dispositivo.
  • Il servizio viene avviato da un'app che fornisce il VoiceInteractionService.
  • Il servizio viene avviato da un'app che dispone dell'autorizzazione privilegiata START_ACTIVITIES_FROM_BACKGROUND.

Determina quali servizi sono interessati nella tua app

Quando testi l'app, avvia i relativi servizi in primo piano. Se un servizio avviato ha accesso limitato a posizione, microfono e fotocamera, in Logcat viene visualizzato il seguente messaggio:

Foreground service started from background can not have \
location/camera/microphone access: service SERVICE_NAME