Questa pagina mostra come integrare Accedi con Google in un'app per iOS o macOS. Potresti dover adattare queste istruzioni 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.
1. Gestire l'URL di reindirizzamento dell'autenticazione
iOS: UIApplicationDelega
Nel metodo application:openURL:options
di AppDelega, 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: NSApplicationDelega
Nell'AppDelega dell'app registra un gestore per gli eventi
kAEGetURL
inapplicationDidFinishLaunching
: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]; }
Definisci il gestore per questi eventi che chiamano
handleURL
diGIDSignIn
: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
GIDSignIn
handleURL
:
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 della tua 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 utilizzano il metodo application:didFinishLaunchingWithOptions:
di UIApplicationDelegate
e applicationDidFinishLaunching:
per le app macOS di NSApplicationDelegate
. Utilizza il risultato per determinare quale vista 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 vista 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
Assicurati di aver aggiunto la dipendenza per il pulsante "Accedi con Google" di SwiftUI al progetto.
Nel file in cui vuoi aggiungere il pulsante SwiftUI, aggiungi l'importazione richiesta nella parte superiore del file:
import GoogleSignInSwift
Aggiungi un pulsante "Accedi con Google" alla vista e specifica l'azione che verrà richiamata quando il pulsante verrà premuto:
GoogleSignInButton(action: handleSignInButton)
Attiva la procedura di accesso quando viene premuto il pulsante aggiungendo una chiamata al metodo
signIn(presentingViewController:completion:)
diGIDSignIn
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
Aggiungi un pulsante "Accedi con Google" alla vista di accesso. Puoi utilizzare la classe
GIDSignInButton
per generare automaticamente un pulsante con il branding di Google (opzione consigliata) o creare un pulsante personalizzato 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 suGIDSignInButton
. Tieni presente che quando aggiungi una visualizzazioneGIDSignInButton
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
estyle
:Proprietà di stile GIDSignInButton colorScheme
kGIDSignInButtonColorSchemeLight
kGIDSignInButtonColorSchemeDark
style
kGIDSignInButtonStyleStandard
kGIDSignInButtonStyleWide
kGIDSignInButtonStyleIconOnly
Collega il pulsante a un metodo nel ViewController che chiama
signIn:
. Ad esempio, utilizza unIBAction
: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. Aggiungi un pulsante di disconnessione
Aggiungi un pulsante di disconnessione alla tua app, visibile agli utenti che hanno eseguito l'accesso.
Collega il pulsante a un metodo nel ViewController che chiama
signOut:
. Ad esempio, utilizza unIBAction
: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:
- Recuperare le informazioni del profilo dell'Account Google degli utenti.
- Esegui l'autenticazione nel backend utilizzando il token ID Google dell'utente.
- Chiamare le API di Google per conto dell'utente.