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

Autentica con Firebase su iOS utilizzando un sistema di autenticazione personalizzato

Puoi integrare Firebase Authentication con un sistema di autenticazione personalizzato modificando il tuo server di autenticazione per produrre token firmati personalizzati quando un utente accede correttamente. La tua app riceve questo token e lo utilizza per autenticarsi con Firebase.

Prima di iniziare

  1. Aggiungi Firebase al tuo progetto iOS .
  2. Includi i seguenti pod nel tuo Podfile :
    pod 'Firebase/Auth'
    
  3. Ottieni le chiavi del server del tuo progetto:
    1. Vai alla pagina Account di servizio nelle impostazioni del tuo progetto.
    2. Fai clic su Genera nuova chiave privata nella parte inferiore della sezione Firebase Admin SDK della pagina Account di servizio .
    3. La coppia di chiavi pubblica / privata del nuovo account di servizio viene salvata automaticamente sul computer. Copia questo file sul tuo server di autenticazione.

Autentica con Firebase

  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. Quando gli utenti accedono alla tua app, invia le loro credenziali di accesso (ad esempio, nome utente e password) al tuo server di autenticazione. Il tuo server controlla le credenziali e restituisce un token personalizzato se sono valide.
  4. Dopo aver ricevuto il token personalizzato dal server di autenticazione, signInWithCustomToken a signInWithCustomToken per accedere all'utente:

    Swift

    Auth.auth().signIn(withCustomToken: customToken ?? "") { (user, error) in
      // ...
    }

    Obiettivo-C

    [[FIRAuth auth] signInWithCustomToken:customToken
                               completion:^(FIRAuthDataResult * _Nullable authResult,
                                            NSError * _Nullable error) {
      // ...
    }];

Prossimi passi

Dopo che un utente accede per la prima volta, viene creato un nuovo account utente e collegato alle credenziali, ovvero il nome utente e la password, il numero di telefono o le informazioni del provider di autenticazione, con cui l'utente ha effettuato l'accesso. Questo nuovo account viene archiviato come parte del progetto Firebase e può essere utilizzato per identificare un utente in ogni app del progetto, indipendentemente da come l'utente effettua l'accesso.

  • Nelle tue app, puoi ottenere le informazioni di base sul profilo FIRUser dall'oggetto FIRUser . Vedi Gestisci utenti .

  • Nelle regole di sicurezza di Firebase Realtime Database e Cloud Storage, puoi ottenere l'ID utente univoco dell'utente connesso 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:

Swift

    let firebaseAuth = Auth.auth()
do {
  try firebaseAuth.signOut()
} catch let signOutError as NSError {
  print ("Error signing out: %@", signOutError)
}
  

Obiettivo-C

    NSError *signOutError;
BOOL status = [[FIRAuth auth] signOut:&signOutError];
if (!status) {
  NSLog(@"Error signing out: %@", signOutError);
  return;
}

Potresti anche voler aggiungere il codice di gestione degli errori per l'intera gamma di errori di autenticazione. Vedere Gestione degli errori .