Saltare al contenuto

Login Google su iOS

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.

In questo capitolo, imparerai a configurare il login di Google su iOS.

  1. Crea un ID client iOS nel console di Google

    1. Clicca sulla barra di ricerca

      Barra di ricerca del console di Google
    2. Cerca credentials e clicca sul APIs and Services uno (numero 2 nella schermata)

      Risultati della ricerca mostranti l'opzione credenziali con API e Servizi evidenziati
    3. Clicca sul create credentials

      Pulsante Crea credenziali nel console di Google
    4. Seleziona OAuth client ID

      Seleziona l'opzione ID del client OAuth nel menu di creazione delle credenziali
    5. Seleziona il Application type per iOS

      Seleziona il tipo di applicazione con l'opzione iOS evidenziata
    6. Trova l'ID del bundle

      1. Apri Xcode

      2. Clicca due volte su App

        Obiettivo dell'app nel navigatore dei progetti Xcode
      3. Assicurati di essere su Targets -> App

        Sezione Obiettivi in Xcode con App selezionata
      4. Trova il tuo Bundle Identifier

        Campo Identificatore Bundle nelle impostazioni del progetto Xcode
      5. Torna al Console di Google e incolla il tuo Bundle Identifier in Bundle ID

        Campo Identificatore Bundle nella forma di creazione del client iOS del Console di Google
    7. Se desiderato, aggiungi il tuo App Store ID o Team ID nel campo ID client se hai pubblicato il tuo app su App Store

    8. Dopo aver riempito tutti i dettagli, clicca create

      Clicca sul pulsante
    9. OK sul dialogo di conferma dell'ID client creato OK

      Apri il client iOS appena creato
    10. __CAPGO_KEEP_0__

      Client iOS creato di recente nella lista delle credenziali
    11. Copia i dati seguenti

      Dettagli del Client ID che mostrano l'ID del client e l'ID del client invertito per copiarli
  2. chiamata.

    1. Apri Xcode e trova il file Info.plist file

      il file Info.plist nel navigatore del progetto Xcode
    2. Fai clic destro su questo file e apriolo come fonte code

      Menu a discesa destro mostrante l'opzione Apri come fonte Code
    3. In fondo al tuo Plist file, vedrai una </dict> etichetta

      Etichetta di chiusura del dizionario in file Info.plist
    4. 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

      Etichetta di chiusura del dizionario in Info.plist con schemi URL code inseriti prima della chiusura
      <key>CFBundleURLTypes</key>
      <array>
      <dict>
      <key>CFBundleURLSchemes</key>
      <array>
      <string>YOUR_DOT_REVERSED_IOS_CLIENT_ID</string>
      </array>
      </dict>
      </array>
    5. Cambia il YOUR_DOT_REVERSED_IOS_CLIENT_ID in il valore copiato nel passo precedente

      Info.plist con il client ID reale inserito nelle URL delle scheme
    6. Salva il file con Command + S

  3. Modifica il AppDelegate.swift

    1. Apri il AppDelegate

      AppDelegate.swift file in Xcode project navigator
    2. Inserisci import GoogleSignIn in cima al file

      AppDelegate.swift con l'importazione di GoogleSignIn aggiunta
    3. Trova il func application(_ app: UIApplication, open url: URL, options: [UIApplication.OpenURLOptionsKey: Any] = [:]) funzione

      Funzione di apertura dell'applicazione originale in AppDelegate
    4. 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 call
      var handled: Bool
      handled = GIDSignIn.sharedInstance.handle(url)
      if handled {
      return true
      }
      return ApplicationDelegateProxy.shared.application(app, open: url, options: options)
      }
      Funzione di apertura dell'applicazione modificata con gestione di GoogleSignIn
    5. Salva il file con Command + S

  4. Configura il login con Google nel tuo JavaScript/TypeScript code

    1. Importa SocialLogin e Capacitor

      import { SocialLogin } from '@capgo/capacitor-social-login';
      import { Capacitor } from '@capacitor/core';
    2. 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 specific
      onMounted(() => {
      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 support
      iOSClientId: 'YOUR_IOS_CLIENT_ID', // Required: from step 1
      iOSServerClientId: 'YOUR_WEB_CLIENT_ID', // Optional: same as webClientId, needed for some advanced features
      mode: 'online' // 'online' or 'offline'
      }
      })
      })
    3. 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 data
      console.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 mode
      console.log('Server auth code:', res.result.serverAuthCode)
  5. Testa la tua applicazione

    1. Costruisci l'applicazione e eseguila cap sync

    2. Se hai fatto tutto correttamente, dovresti vedere il flusso di accesso Google che funziona correttamente

      Demo del flusso di accesso Google su iOS che mostra il processo di accesso e l'autenticazione riuscita

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: {}
});