Saltare al contenuto

Supabase Google Login su Android

Questa guida ti aiuterà a integrare l'accesso con Google con l'autenticazione di Supabase su Android. Si assume che tu abbia già completato:

L'implementazione completa è disponibile nel file dell'applicazione di esempio. Questa guida spiega i concetti chiave e come utilizzarla. supabaseAuthUtils.ts Utilizzo dell'helper di autenticazione

Sottosezione intitolata “Utilizzo dell'helper di autenticazione”

La

funzione gestisce l'intero flusso di autenticazione: authenticateWithGoogleSupabase Copia nella clipboard

import { authenticateWithGoogleSupabase } from './supabaseAuthUtils';
const result = await authenticateWithGoogleSupabase();
if (result.success) {
console.log('Signed in:', result.user);
// Navigate to your authenticated area
} else {
console.error('Error:', result.error);
}

Per una spiegazione dettagliata di come funziona il flusso di autenticazione, compresa la generazione del nonce, la validazione del JWT e l'accesso a Supabase, vedere il Sottosezione intitolata “Come funziona” nella guida di configurazione generale.

Per la documentazione completa del code, vedere la Sottosezione intitolata “Documentazione completa del Code” nella guida di configurazione generale.

L'implementazione del nonce segue il modello dal documentazione di React Native Google Sign In:

  • rawNonce va a Supabase’s signInWithIdToken()
  • Supabase genera un hash di rawNonce e lo confronta con il nonceDigest che è incluso nel token ID da Google Sign-In
  • nonceDigest (hash SHA-256, codificato in esadecimale) va al nonce parametro nelle API di Google Sign-In

L'implementazione include la logica di ritentativo automatico:

  • Se la validazione del JWT fallisce all'atto primo, si esce e si ritenta una volta
  • Questo gestisce i casi in cui i token memorizzati potrebbero avere nonces errati
  • Se anche il ritentativo fallisce, viene restituito un errore

Se fallisce l'autenticazione:

  • Audience non valido: Verifica che i Client ID Google siano uguali in entrambi Google Cloud Console e Supabase
  • Mancato match del nonce: Controlla i log del console - la funzione si riproverà automaticamente, ma puoi effettuare il logout manualmente se necessario
  • Fallimento della validazione del token: Assicurati di utilizzare mode: 'online' in l'istanza di inizializzazione per ottenere un idToken
  • Recensisci l'applicazione di esempio __CAPGO_KEEP_0__ example app code per riferimento

Se stai utilizzando Supabase Google Login su Android per pianificare l'autenticazione e le flussi di account, connettilo con Utilizzando @capgo/capacitor-login-social per la capacità nativa in Utilizzando @capgo/capacitor-login-social, @capgo/capacitor-login-social per il dettaglio di implementazione in @capgo/capacitor-login-social, @capgo/capacitor-passkey per il dettaglio di implementazione in @capgo/capacitor-passkey, per la dettagliata implementazione in @capgo/capacitor-native-biometric, e per la dettagliata implementazione in @capgo/capacitor-native-biometric, e Autenticazione a due fattori per la dettagliata implementazione in Autenticazione a due fattori.