Login Google su iOS
Copiare un prompt di configurazione con i passaggi di installazione e la guida markdown completa per questo plugin.
Introduzione
Sezione intitolata “Introduzione”In questo guide, imparerai a configurare l'accesso Google con Capgo Social Login per iOS. Assumo che tu abbia già letto la guida di configurazione generale.
Usare il login di Google su iOS
Sezione intitolata “Usare il login di Google su iOS”In questo capitolo, imparerai a configurare il login di Google su iOS.
-
Crea un ID client iOS nel console di Google
-
Clicca sulla barra di ricerca
-
Cerca
credentialse clicca sulAPIs and Servicesuno (numero 2 nella schermata)
-
Clicca sul
create credentials
-
Seleziona
OAuth client ID
-
Seleziona il
Application typeperiOS
-
Trova l'ID del bundle
-
Apri Xcode
-
Clicca due volte su
App
-
Assicurati di essere su
Targets -> App
-
Trova il tuo
Bundle Identifier
-
Torna al Console di Google e incolla il tuo
Bundle IdentifierinBundle ID
-
-
Se desiderato, aggiungi il tuo
App Store IDoTeam IDnel campo ID client se hai pubblicato il tuo app su App Store -
Dopo aver riempito tutti i dettagli, clicca
create
-
OK sul dialogo di conferma dell'ID client creato
OK
-
__CAPGO_KEEP_0__
-
Copia i dati seguenti
-
-
chiamata.
-
Apri Xcode e trova il file
Info.plistfile
-
Fai clic destro su questo file e apriolo come fonte code
-
In fondo al tuo
Plistfile, vedrai una</dict>etichetta
-
Inserisci il seguente frammento prima della chiusura
</dict>Etichetta di chiusura del dizionario in Info.plist con schemi URL __CAPGO_KEEP_0__ inseriti prima della chiusura
<key>CFBundleURLTypes</key><array><dict><key>CFBundleURLSchemes</key><array><string>YOUR_DOT_REVERSED_IOS_CLIENT_ID</string></array></dict></array> -
Cambia il
YOUR_DOT_REVERSED_IOS_CLIENT_IDin il valore copiato nel passo precedente
-
Salva il file con
Command + S
-
-
Modifica il
AppDelegate.swift-
Apri il AppDelegate
-
Inserisci
import GoogleSignInin cima al file
-
Trova il
func application(_ app: UIApplication, open url: URL, options: [UIApplication.OpenURLOptionsKey: Any] = [:])funzione
-
Modifica la funzione per farla assomigliare a questa
func application(_ app: UIApplication, open url: URL, options: [UIApplication.OpenURLOptionsKey: Any] = [:]) -> Bool {// Called when the app was launched with a url. Feel free to add additional processing here,// but if you want the App API to support tracking app url opens, make sure to keep this callvar handled: Boolhandled = GIDSignIn.sharedInstance.handle(url)if handled {return true}return ApplicationDelegateProxy.shared.application(app, open: url, options: options)}
-
Salva il file con
Command + S
-
-
Configura il login con Google nel tuo JavaScript/TypeScript code
-
Importa
SocialLogineCapacitorimport { SocialLogin } from '@capgo/capacitor-social-login';import { Capacitor } from '@capacitor/core'; -
Chiamare il metodo di inizializzazione (questo dovrebbe essere chiamato solo una volta)
Configurazione base (modalità online - consigliata per la maggior parte degli app):
// onMounted is Vue specificonMounted(() => {SocialLogin.initialize({google: {iOSClientId: '673324426943-redacted.apps.googleusercontent.com',mode: 'online' // Default mode}})})Configurazione avanzata con ID client aggiuntivi:
onMounted(() => {SocialLogin.initialize({google: {webClientId: 'YOUR_WEB_CLIENT_ID', // Optional: for web platform supportiOSClientId: 'YOUR_IOS_CLIENT_ID', // Required: from step 1iOSServerClientId: 'YOUR_WEB_CLIENT_ID', // Optional: same as webClientId, needed for some advanced featuresmode: 'online' // 'online' or 'offline'}})}) -
Implementa la funzione di accesso. Crea un pulsante e esegui il seguente code al click
Per la modalità online:
const res = await SocialLogin.login({provider: 'google',options: {}})// handle the response - contains user dataconsole.log(JSON.stringify(res))Per modalità offline:
const res = await SocialLogin.login({provider: 'google',options: {forceRefreshToken: true // Recommended for offline mode}})// res contains serverAuthCode, not user data// Send serverAuthCode to your backend to get user information// Do not call SocialLogin.refresh() in offline modeconsole.log('Server auth code:', res.result.serverAuthCode)
-
-
Testa la tua applicazione
-
Costruisci l'applicazione e eseguila
cap sync -
Se hai fatto tutto correttamente, dovresti vedere il flusso di accesso Google che funziona correttamente
-
Problemi noti
Sezione intitolata “Problemi noti”Incompatibilità del plugin della schermata di accesso alle informazioni personali
Sezione intitolata “Incompatibilità del plugin della schermata di privacy”Il plugin di accesso Google è incompatibile con @capacitor/privacy-screenQuando si utilizzano entrambi i plugin insieme, la schermata di login webview di Google verrà interrotta dalla schermata di privacy.
Soluzione alternativa: Chiamare await PrivacyScreen.disable(); prima di chiamare la funzione di login:
import { PrivacyScreen } from '@capacitor/privacy-screen';import { SocialLogin } from '@capgo/capacitor-social-login';
await PrivacyScreen.disable();await SocialLogin.login({ provider: 'google', options: {}});