Esegui l'autenticazione con Firebase in modo anonimo

Puoi utilizzare Firebase Authentication per creare e utilizzare account anonimi temporanei per l'autenticazione con Firebase. Questi account anonimi temporanei possono essere utilizzati per consentire agli utenti che non hanno ancora eseguito la registrazione alla tua app di lavorare con i dati protetti dalle regole di sicurezza. Se un utente anonimo decide di registrarsi alla tua app, puoi collegare le sue credenziali di accesso all'account anonimo in modo che possa continuare a lavorare con i dati protetti nelle sessioni future.

Prima di iniziare

  1. Se non l'hai ancora fatto, segui i passaggi della guida Inizia.

  2. Abilita l'accesso anonimo:

    • Nella sezione Autenticazione della console Firebase, apri la pagina Metodo di accesso.
    • Nella pagina Metodo di accesso, abilita il metodo di accesso Accesso anonimo e fai clic su Salva.

Eseguire l'autenticazione con Firebase in modo anonimo

Quando un utente che non ha eseguito l'accesso utilizza una funzionalità dell'app che richiede l'autenticazione con Firebase, esegui l'accesso dell'utente in modo anonimo chiamando signInAnonymously():

try {
  final userCredential =
      await FirebaseAuth.instance.signInAnonymously();
  print("Signed in with temporary account.");
} on FirebaseAuthException catch (e) {
  switch (e.code) {
    case "operation-not-allowed":
      print("Anonymous auth hasn't been enabled for this project.");
      break;
    default:
      print("Unknown error.");
  }
}

Convertire un account anonimo in un account permanente

Quando un utente anonimo si registra alla tua app, potresti voler consentirgli di continuare a lavorare con il suo nuovo account. Ad esempio, potresti voler rendere disponibili gli articoli che l'utente ha aggiunto al carrello degli acquisti prima della registrazione nel carrello degli acquisti del nuovo account. Per farlo, segui questa procedura.

  1. Quando l'utente si registra, completa il flusso di accesso per il provider di autenticazione dell'utente fino alla chiamata di uno dei metodi signInWith-, ma non includerla. Ad esempio, recupera il token ID Google, il token di accesso di Facebook o l'indirizzo email e la password dell'utente.

  2. Recupera un oggetto Credential per il nuovo provider di autenticazione:

    // Google Sign-in
    final credential = GoogleAuthProvider.credential(idToken: idToken);
    
    // Email and password sign-in
    final credential =
        EmailAuthProvider.credential(email: emailAddress, password: password);
    
    // Etc.
    
  3. Passa l'oggetto Credential al linkWithCredential() metodo dell'utente che ha eseguito l'accesso:

    try {
      final userCredential = await FirebaseAuth.instance.currentUser
          ?.linkWithCredential(credential);
    } on FirebaseAuthException catch (e) {
      switch (e.code) {
        case "provider-already-linked":
          print("The provider has already been linked to the user.");
          break;
        case "invalid-credential":
          print("The provider's credential is not valid.");
          break;
        case "credential-already-in-use":
          print("The account corresponding to the credential already exists, "
              "or is already linked to a Firebase User.");
          break;
        // See the API reference for the full list of error codes.
        default:
          print("Unknown error.");
      }
      ```
    

Se la chiamata a linkWithCredential() va a buon fine, il nuovo account dell'utente può accedere ai dati Firebase dell'account anonimo.

Passaggi successivi

Dopo che un utente ha creato un nuovo account, questo viene archiviato come parte del tuo progetto Firebase e può essere utilizzato per identificare un utente in ogni app del tuo progetto, indipendentemente dal metodo di accesso utilizzato.

Nelle tue app, puoi recuperare le informazioni di base del profilo dell'utente dall'oggetto User. Consulta Gestire gli utenti.

Nelle regole di sicurezza di Firebase Realtime Database e Cloud Storage, puoi recuperare l'ID utente univoco dell'utente che ha eseguito l'accesso dalla variabile auth e utilizzarlo per controllare i dati a cui un utente può accedere.

Puoi consentire agli utenti di accedere alla tua app utilizzando più provider di autenticazione collegando le credenziali del provider di autenticazione) a un account utente esistente.

Per disconnettere un utente, chiama signOut():

await FirebaseAuth.instance.signOut();