Integrazione di Accedi con Google nell'app per iOS o macOS

Questa pagina mostra come integrare Accedi con Google in un'app per iOS o macOS. Potresti dover adattare queste istruzioni in base al ciclo di vita o al modello di UI della tua app.

Prima di iniziare

Scarica le dipendenze, configura il progetto Xcode e imposta il tuo ID client.

Prova la nostra app di esempio per iOS e macOS per vedere come funziona l'accesso.

1. Gestire l'URL di reindirizzamento dell'autenticazione

iOS: UIApplicationDelega

Nel metodo application:openURL:options di AppDelegate, chiama il metodo handleURL: di GIDSignIn:

Swift

func application(
  _ app: UIApplication,
  open url: URL, options: [UIApplication.OpenURLOptionsKey : Any] = [:]
) -> Bool {
  var handled: Bool

  handled = GIDSignIn.sharedInstance.handle(url)
  if handled {
    return true
  }

  // Handle other custom URL types.

  // If not handled by this app, return false.
  return false
}

Objective-C

- (BOOL)application:(UIApplication *)app
            openURL:(NSURL *)url
            options:(NSDictionary<UIApplicationOpenURLOptionsKey,id> *)options {
  BOOL handled;

  handled = [GIDSignIn.sharedInstance handleURL:url];
  if (handled) {
    return YES;
  }

  // Handle other custom URL types.

  // If not handled by this app, return NO.
  return NO;
}

macOS: NSApplicationDelegate

  1. Nell'AppDelega dell'app, registra un gestore per gli eventi kAEGetURL in applicationDidFinishLaunching:

    Swift

    func applicationDidFinishLaunching(_ notification: Notification) {
      // Register for GetURL events.
      let appleEventManager = NSAppleEventManager.shared()
      appleEventManager.setEventHandler(
        self,
        andSelector: "handleGetURLEvent:replyEvent:",
        forEventClass: AEEventClass(kInternetEventClass),
        andEventID: AEEventID(kAEGetURL)
      )
    }
    

    Objective-C

    - (void)applicationDidFinishLaunching:(NSNotification *)aNotification {
      // Register for GetURL events.
      NSAppleEventManager *appleEventManager = [NSAppleEventManager sharedAppleEventManager];
      [appleEventManager setEventHandler:self
                         andSelector:@selector(handleGetURLEvent:withReplyEvent:)
                         forEventClass:kInternetEventClass
                         andEventID:kAEGetURL];
    }
    
  2. Definisci il gestore per questi eventi che chiamano il handleURL di GIDSignIn:

    Swift

    func handleGetURLEvent(event: NSAppleEventDescriptor?, replyEvent: NSAppleEventDescriptor?) {
        if let urlString =
          event?.paramDescriptor(forKeyword: AEKeyword(keyDirectObject))?.stringValue{
            let url = NSURL(string: urlString)
            GIDSignIn.sharedInstance.handle(url)
        }
    }
    

    Objective-C

    - (void)handleGetURLEvent:(NSAppleEventDescriptor *)event
               withReplyEvent:(NSAppleEventDescriptor *)replyEvent {
          NSString *URLString = [[event paramDescriptorForKeyword:keyDirectObject] stringValue];
          NSURL *URL = [NSURL URLWithString:URLString];
          [GIDSignIn.sharedInstance handleURL:url];
    }
    

SwiftUI

Nella finestra o nella scena dell'app, registra un gestore per ricevere l'URL e chiamare handleURL GIDSignIn:

Swift

@main
struct MyApp: App {

  var body: some Scene {
    WindowGroup {
      ContentView()
        // ...
        .onOpenURL { url in
          GIDSignIn.sharedInstance.handle(url)
        }
    }
  }
}

2. Tentativo di ripristinare lo stato di accesso dell'utente

All'avvio dell'app, chiama restorePreviousSignInWithCallback per provare a ripristinare lo stato di accesso degli utenti che hanno già eseguito l'accesso utilizzando Google. In questo modo gli utenti non dovranno eseguire l'accesso ogni volta che aprono la tua app (a meno che non siano usciti).

Le app per iOS spesso fanno questa operazione nel metodo application:didFinishLaunchingWithOptions: di UIApplicationDelegate e nel metodo applicationDidFinishLaunching: di NSApplicationDelegate per le app macOS. Utilizza il risultato per determinare quale visualizzazione presentare all'utente. Ad esempio:

Swift

func application(
  _ application: UIApplication,
  didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?
) -> Bool {
  GIDSignIn.sharedInstance.restorePreviousSignIn { user, error in
    if error != nil || user == nil {
      // Show the app's signed-out state.
    } else {
      // Show the app's signed-in state.
    }
  }
  return true
}

Objective-C

- (BOOL)application:(UIApplication *)application
    didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
  [GIDSignIn.sharedInstance restorePreviousSignInWithCompletion:^(GIDGoogleUser * _Nullable user,
                                                                  NSError * _Nullable error) {
    if (error) {
      // Show the app's signed-out state.
    } else {
      // Show the app's signed-in state.
    }
  }];
  return YES;
}

SwiftUI

Se utilizzi SwiftUI, aggiungi una chiamata a restorePreviousSignIn in onAppear per la visualizzazione iniziale:

Swift

@main
struct MyApp: App {
  var body: some Scene {
    WindowGroup {
      ContentView()
        // ...
        .onAppear {
          GIDSignIn.sharedInstance.restorePreviousSignIn { user, error in
            // Check if `user` exists; otherwise, do something with `error`
          }
        }
    }
  }
}

3. Aggiungi un pulsante Accedi con Google

Aggiungi un pulsante "Accedi con Google" alla visualizzazione di accesso. Per SwiftUI e UIKit sono disponibili componenti che generano automaticamente un pulsante con il branding di Google e sono consigliati per l'uso.

Utilizzo di SwiftUI

  1. Assicurati di aver aggiunto la dipendenza per il pulsante "Accedi con Google" di SwiftUI al tuo progetto.

  2. Nel file in cui vuoi aggiungere il pulsante SwiftUI, aggiungi l'importazione richiesta all'inizio del file:

    import GoogleSignInSwift
    
  3. Aggiungi un pulsante "Accedi con Google" alla vista e specifica l'azione che verrà richiamata quando il pulsante viene premuto:

    GoogleSignInButton(action: handleSignInButton)
    
  4. Attiva la procedura di accesso quando viene premuto il pulsante aggiungendo una chiamata al metodo signIn(presentingViewController:completion:) di GIDSignIn nell'azione:

    func handleSignInButton() {
      GIDSignIn.sharedInstance.signIn(
        withPresenting: rootViewController) { signInResult, error in
          guard let result = signInResult else {
            // Inspect error
            return
          }
          // If sign in succeeded, display the app's main content View.
        }
      )
    }
    

Viene utilizzato il modello di visualizzazione predefinito che fornisce informazioni sullo stile standard per il pulsante. Per controllare l'aspetto del pulsante, devi creare un elemento GoogleSignInButtonViewModel personalizzato e impostarlo come viewModel nell'inizializzazione del pulsante utilizzando GoogleSignInButton(viewModel: yourViewModel, action: yourAction). Consulta il codice sorgente di GoogleSignInButtonViewModel per ulteriori informazioni.

Utilizzo di UIKit

  1. Aggiungi un pulsante "Accedi con Google" alla visualizzazione di accesso. Puoi utilizzare la classe GIDSignInButton per generare automaticamente un pulsante con il branding di Google (consigliato) o creare il tuo pulsante con stili personalizzati.

    Per aggiungere un elemento GIDSignInButton a uno storyboard o a un file XIB, aggiungi una vista e imposta la relativa classe personalizzata su GIDSignInButton. Tieni presente che quando aggiungi una visualizzazione GIDSignInButton allo storyboard, il pulsante di accesso non viene visualizzato nello strumento di creazione di interfacce. Esegui l'app per visualizzare il pulsante di accesso.

    Puoi personalizzare l'aspetto di un elemento GIDSignInButton impostando le relative proprietà colorScheme e style:

    Proprietà di stile GIDSignInButton
    colorScheme kGIDSignInButtonColorSchemeLight
    kGIDSignInButtonColorSchemeDark
    style kGIDSignInButtonStyleStandard
    kGIDSignInButtonStyleWide
    kGIDSignInButtonStyleIconOnly
  2. Connetti il pulsante a un metodo in ViewController che chiama signIn:. Ad esempio, utilizza un IBAction:

    Swift

    @IBAction func signIn(sender: Any) {
      GIDSignIn.sharedInstance.signIn(withPresenting: self) { signInResult, error in
        guard error == nil else { return }
    
        // If sign in succeeded, display the app's main content View.
      }
    }
    

    Objective-C

    - (IBAction)signIn:(id)sender {
      [GIDSignIn.sharedInstance
          signInWithPresentingViewController:self
                                  completion:^(GIDSignInResult * _Nullable signInResult,
                                               NSError * _Nullable error) {
        if (error) {
          return;
        }
    
        // If sign in succeeded, display the app's main content View.
      }];
    }
    

4. Aggiungere un pulsante di uscita

  1. Aggiungi alla tua app un pulsante di uscita, visibile agli utenti che hanno eseguito l'accesso.

  2. Connetti il pulsante a un metodo in ViewController che chiama signOut:. Ad esempio, utilizza un IBAction:

    Swift

    @IBAction func signOut(sender: Any) {
      GIDSignIn.sharedInstance.signOut()
    }
    

    Objective-C

    - (IBAction)signOut:(id)sender {
      [GIDSignIn.sharedInstance signOut];
    }
    

Passaggi successivi

Ora che gli utenti possono accedere alla tua app utilizzando i propri Account Google, scopri come: