Questa pagina è stata tradotta dall'API Cloud Translation.
Switch to English

Autentica con Firebase in modo anonimo su iOS

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 si sono ancora registrati 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 suoi dati protetti nelle sessioni future.

Prima di iniziare

  1. Aggiungi Firebase al tuo progetto iOS .
  2. Includi i seguenti pod nel tuo Podfile :
    pod 'Firebase/Auth'
    
  3. Se non hai ancora collegato la tua app al tuo progetto Firebase, fallo dalla console Firebase .
  4. Abilita autenticazione anonima:
    1. Nella console Firebase , apri la sezione Autenticazione .
    2. Nella pagina Metodi di accesso , abilitare il metodo di accesso anonimo .

Autentica con Firebase in modo anonimo

Quando un utente disconnesso utilizza una funzionalità dell'app che richiede l'autenticazione con Firebase, accedi all'utente in modo anonimo completando i seguenti passaggi:

  1. Importa il modulo Firebase nella tua UIApplicationDelegate :

    Swift

    import Firebase

    Obiettivo-C

    @import Firebase;
  2. Configura un'istanza condivisa FirebaseApp , in genere nell'applicazione della tua app application:didFinishLaunchingWithOptions: metodo:

    Swift

    // Use Firebase library to configure APIs
    FirebaseApp.configure()

    Obiettivo-C

    // Use Firebase library to configure APIs
    [FIRApp configure];
  3. Chiama il metodo signInAnonymouslyWithCompletion: ::

    Swift

    Auth.auth().signInAnonymously() { (authResult, error) in
      // ...
    }
    

    Obiettivo-C

    [[FIRAuth auth] signInAnonymouslyWithCompletion:^(FIRAuthDataResult * _Nullable authResult,
                                                      NSError * _Nullable error) {
       // ...
     }];
    
  4. Se il metodo signInAnonymouslyWithCompletion: viene completato senza errori, è possibile ottenere i dati dell'account dell'utente anonimo dall'oggetto FIRAuthDataResult :

    Swift

    guard let user = authResult?.user else { return }
    let isAnonymous = user.isAnonymous  // true
    let uid = user.uid
    

    Obiettivo-C

    FIRUser *user = authResult.user;
    BOOL isAnonymous = user.anonymous;  // YES
    NSString *uid = user.uid;
    

Converti un account anonimo in un account permanente

Quando un utente anonimo si iscrive alla tua app, potresti voler consentire loro di continuare a lavorare con il suo nuovo account, ad esempio potresti voler rendere gli articoli che l'utente ha aggiunto al carrello prima di registrarsi disponibili nel suo nuovo carrello degli acquisti dell'account. A tale scopo, completare i seguenti passaggi:

  1. Quando l'utente si iscrive, completa il flusso di accesso per il provider di autenticazione dell'utente fino a chiamare uno dei metodi FIRAuth.signInWith , ma escluso. Ad esempio, ottieni il token dell'ID Google dell'utente, il token di accesso a Facebook o l'indirizzo e-mail e la password.
  2. Ottieni un FIRAuthCredential per il nuovo provider di autenticazione:

    Accesso a Google
    Swift
    guard let authentication = user.authentication else { return }
    let credential = GoogleAuthProvider.credential(withIDToken: authentication.idToken,
                                                      accessToken: authentication.accessToken)
    
    Obiettivo-C
    GIDAuthentication *authentication = user.authentication;
    FIRAuthCredential *credential =
    [FIRGoogleAuthProvider credentialWithIDToken:authentication.idToken
                                     accessToken:authentication.accessToken];
    
    Accesso a Facebook
    Swift
    let credential = FacebookAuthProvider.credential(withAccessToken: AccessToken.current!.tokenString)
    
    Obiettivo-C
    FIRAuthCredential *credential = [FIRFacebookAuthProvider
        credentialWithAccessToken:[FBSDKAccessToken currentAccessToken].tokenString];
    
    Accesso tramite e-mail con password
    Swift
    let credential = EmailAuthProvider.credential(withEmail: email, password: password)
    
    Obiettivo-C
    FIRAuthCredential *credential =
        [FIREmailAuthProvider credentialWithEmail:email
                                                 password:password];
    
  3. Passa l'oggetto FIRAuthCredential al FIRAuthCredential dell'utente di linkWithCredential:completion: metodo:

    Swift
        user.link(with: credential) { (authResult, error) in
      // ...
    }
    }
    
    Obiettivo-C
        [[FIRAuth auth].currentUser linkWithCredential:credential
        completion:^(FIRAuthDataResult *result, NSError *_Nullable error) {
      // ...
    }];
    

Se la chiamata a linkWithCredential:completion: riesce, il nuovo account dell'utente può accedere ai dati Firebase dell'account anonimo.

Prossimi passi

Ora che gli utenti possono autenticarsi con Firebase, puoi controllare il loro accesso ai dati nel tuo database Firebase utilizzando le regole Firebase .