Esta página mostra como integrar o Login do Google a um app iOS ou macOS. Talvez você precise adaptar essas instruções para o ciclo de vida ou modelo de IU do app.
Antes de começar
Faça o download das dependências, configure seu projeto do Xcode e o ID do cliente.
1. Processar o URL de redirecionamento de autenticação
iOS: UIApplicationDelegate
No método application:openURL:options
do AppDelegate, chame o método handleURL:
do 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
No AppDelegate do app, registre um gerenciador para eventos
kAEGetURL
emapplicationDidFinishLaunching
: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]; }
Defina o manipulador para esses eventos que chama o
handleURL
daGIDSignIn
: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
Na janela ou cena do app, registre um gerenciador para receber o URL e chame
handleURL
s do GIDSignIn
:
Swift
@main
struct MyApp: App {
var body: some Scene {
WindowGroup {
ContentView()
// ...
.onOpenURL { url in
GIDSignIn.sharedInstance.handle(url)
}
}
}
}
2. Tentativa de restaurar o estado de login do usuário
Quando seu app for iniciado, chame restorePreviousSignInWithCallback
para tentar
restaurar o estado de login dos usuários que já fizeram login usando o Google. Isso
garante que os usuários não precisem fazer login sempre que abrirem o app, a menos que
saiam.
Apps para iOS geralmente fazem isso no método
application:didFinishLaunchingWithOptions:
do UIApplicationDelegate
e no
applicationDidFinishLaunching:
do NSApplicationDelegate
para apps macOS. Use
o resultado para determinar qual visualização apresentar ao usuário. Exemplo:
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 você estiver usando o SwiftUI, adicione uma chamada para restorePreviousSignIn
em onAppear
para
sua visualização inicial:
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. Adicionar um botão de Login do Google
Adicione um botão "Fazer login com o Google" à sua visualização de login. Os componentes estão disponíveis para o SwiftUI e o UIKit, que geram automaticamente um botão com o branding do Google e são recomendados para uso.
Como usar o SwiftUI
Verifique se você adicionou a dependência do botão "Fazer login com o Google" do SwiftUI ao seu projeto.
No arquivo em que você quer incluir o botão do SwiftUI, inclua a importação necessária na parte superior do arquivo:
import GoogleSignInSwift
Adicione um botão "Fazer login com o Google" à visualização e especifique a ação que será chamada quando o botão for pressionado:
GoogleSignInButton(action: handleSignInButton)
Acione o processo de login quando o botão for pressionado adicionando uma chamada para o método
signIn(presentingViewController:completion:)
daGIDSignIn
na sua ação: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. } ) }
Ele usa o modelo de visualização padrão que fornece informações de estilo padrão para
o botão. Para controlar a aparência do botão, crie um
GoogleSignInButtonViewModel
personalizado e defina-o como viewModel
no inicializador do
botão usando GoogleSignInButton(viewModel: yourViewModel, action:
yourAction)
. Consulte o código-fonte GoogleSignInButtonViewModel
para mais informações.
Como usar o UIKit
Adicione um botão "Fazer login com o Google" à sua visualização de login. É possível usar a classe
GIDSignInButton
para gerar automaticamente um botão com o branding do Google (recomendado) ou criar seu próprio botão com estilo personalizado.Para adicionar uma
GIDSignInButton
a um storyboard ou arquivo XIB, inclua uma visualização e defina a classe personalizada dela comoGIDSignInButton
. Quando você adiciona uma visualizaçãoGIDSignInButton
ao storyboard, o botão de login não é renderizado no builder de interface. Execute o app para ver o botão de login.Você pode personalizar a aparência de um
GIDSignInButton
definindo as propriedadescolorScheme
estyle
:Propriedades de estilo GIDSignInButton colorScheme
kGIDSignInButtonColorSchemeLight
kGIDSignInButtonColorSchemeDark
style
kGIDSignInButtonStyleStandard
kGIDSignInButtonStyleWide
kGIDSignInButtonStyleIconOnly
Conecte o botão a um método no ViewController que chame
signIn:
. Por exemplo, use umIBAction
: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. Adicionar um botão para sair
Adicione um botão de saída ao seu app, visível para usuários conectados.
Conecte o botão a um método no ViewController que chame
signOut:
. Por exemplo, use umIBAction
:Swift
@IBAction func signOut(sender: Any) { GIDSignIn.sharedInstance.signOut() }
Objective-C
- (IBAction)signOut:(id)sender { [GIDSignIn.sharedInstance signOut]; }
Próximas etapas
Agora que os usuários podem fazer login no app usando as Contas do Google, saiba como:
- Ver as informações do perfil da Conta do Google dos usuários
- Autentique-se com o back-end usando o token de ID do Google.
- Chamar as APIs do Google em nome do usuário.