Autenticazione anonima con Firebase

Puoi utilizzare Firebase Authentication per creare e utilizzare account anonimi temporanei per eseguire l'autenticazione con Firebase. Questi account anonimi temporanei possono essere utilizzati per: consenti agli utenti che non si sono ancora registrati alla tua app di lavorare con i dati protetti in base alle regole di sicurezza. Se un utente anonimo decide di registrarsi alla tua app, puoi collegare le proprie credenziali di accesso all'account anonimo in modo che di poter continuare a lavorare con i propri dati protetti nelle sessioni future.

Prima di iniziare

  1. Se non lo hai già fatto, segui i passaggi nella Guida introduttiva.

  2. Abilita l'accesso anonimo:

    • Nella sezione Autenticazione della console Firebase, apri il Metodo di accesso .
    • Nella pagina Metodo di accesso, attiva l'opzione Accesso anonimo. e fai clic su Salva.

Eseguire l'autenticazione con Firebase in forma anonima

Quando un utente che non ha eseguito l'accesso utilizza una funzionalità dell'app che richiede l'autenticazione con Firebase, accedi all'utente in modo anonimo chiamando il numero 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 volergli consentire di continuare a lavorare con il suo nuovo account. Ad esempio, potresti rendere disponibili nel carrello del nuovo account gli articoli che l'utente ha aggiunto al carrello prima di registrarsi. Per farlo, completa i seguenti passaggi passaggi:

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

  2. Ottieni 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. Trasmetti l'oggetto Credential al valore linkWithCredential() 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 di Firebase dell'account anonimo.

Passaggi successivi

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

Nelle tue app puoi ottenere le informazioni di base del profilo dell'utente dal User oggetto. Vedi Gestire gli utenti.

In Firebase Realtime Database e regole di sicurezza di Cloud Storage, puoi recupera l'ID utente unico dell'utente che ha eseguito l'accesso dalla variabile auth e utilizzalo per controllare a quali dati può accedere un utente.

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 scollegare un utente, chiama signOut():

await FirebaseAuth.instance.signOut();