Supabase Google Login - Configurazione Generale
Copia un prompt di configurazione con i passaggi di installazione e la guida markdown completa per questo plugin.
Introduzione
Sottosezione intitolata “Introduzione”Questa guida ti guiderà attraverso l'integrazione di Google Sign-In con l'autenticazione Supabase utilizzando il plugin di login sociale Capacitor.
Requisiti preliminari
Sottosezione intitolata “Requisiti preliminari”Prima di iniziare, assicurati di avere:
-
Letto il Setup di Google Login Generale guida per configurare le credenziali OAuth di Google
-
Seguito le guide specifiche per piattaforma per configurare le credenziali OAuth di Google per la tua piattaforma di destinazione:
Abilitare il provider OAuth Google in Supabase
Sezione intitolata “Abilitare il provider OAuth Google in Supabase”-
Vai al tuo Pannello di controllo di Supabase
-
Clicca sul tuo progetto
-
Vai al
Authenticationmenu
-
Clicca sul
Providerstab
-
Trova il
Googleprovider
-
Abilita il provider
-
Aggiungi gli ID client per le piattaforme che intendi utilizzare
-
Clicca sul
Savetasto
Ecco, hai ora abilitato l'accesso con Google con l'autenticazione Supabase 🎉
Come funziona l'accesso con Google con l'aiuto dell'autenticazione Supabase
Sottosezione intitolata “Come funziona l'accesso con Google con l'aiuto dell'autenticazione Supabase”Questa sezione spiega come funziona l'integrazione dell'accesso con Google con Supabase sotto la pelle. Comprendere questo flusso ti aiuterà a implementare e a risolvere i problemi di autenticazione.
1. Generazione di Nonce
Sezione intitolata “1. Generazione di Nonce”L'implementazione genera una coppia di nonce sicura in base alle Requisiti di nonce di Supabase:
// Generate URL-safe random noncefunction getUrlSafeNonce(): string { const array = new Uint8Array(32); crypto.getRandomValues(array); return Array.from(array, (byte) => byte.toString(16).padStart(2, '0')).join('');}
// Hash the nonce with SHA-256async function sha256Hash(message: string): Promise<string> { const encoder = new TextEncoder(); const data = encoder.encode(message); const hashBuffer = await crypto.subtle.digest('SHA-256', data); const hashArray = Array.from(new Uint8Array(hashBuffer)); return hashArray.map((b) => b.toString(16).padStart(2, '0')).join('');}
// Generate nonce pairasync function getNonce(): Promise<{ rawNonce: string; nonceDigest: string }> { const rawNonce = getUrlSafeNonce(); const nonceDigest = await sha256Hash(rawNonce); return { rawNonce, nonceDigest };}Corsa:
rawNonce: Stringa casuale sicura per URL (64 caratteri esadecimali)nonceDigest: Hash SHA-256 dirawNonce(codificato in esadecimale)nonceDigestviene passato a Google Sign-In → Google include il digest nonce nel token IDrawNonceviene passato a Supabase → Supabase hasha la nonce raw e la confronta con il nonce del token
2. Google Sign-In
Sezione intitolata “2. Accesso con Google”La funzione inizializza il plugin e si accede con Google:
await SocialLogin.initialize({ google: { webClientId: 'YOUR_WEB_CLIENT_ID.apps.googleusercontent.com', // iOS only: iOSClientId: 'YOUR_IOS_CLIENT_ID.apps.googleusercontent.com', mode: 'online', // Required to get idToken },});
const response = await SocialLogin.login({ provider: 'google', options: { scopes: ['email', 'profile'], nonce: nonceDigest, // Pass the SHA-256 hashed nonce },});3. Validazione del JWT
Sezione intitolata “3. Validazione del JWT”Prima di inviare il token a Supabase, l'implementazione valuta il token JWT:
function validateJWTToken(idToken: string, expectedNonceDigest: string): { valid: boolean; error?: string } { const decodedToken = decodeJWT(idToken);
// Check audience matches your Google Client IDs const audience = decodedToken.aud; if (!VALID_GOOGLE_CLIENT_IDS.includes(audience)) { return { valid: false, error: 'Invalid audience' }; }
// Check nonce matches const tokenNonce = decodedToken.nonce; if (tokenNonce && tokenNonce !== expectedNonceDigest) { return { valid: false, error: 'Nonce mismatch' }; }
return { valid: true };}Perché validare prima di Supabase?
La validazione del token JWT prima di inviare il token a Supabase serve diversi scopi importanti:
-
Prevenire Richieste Non Valide: Se il token ha un'audience o un nonce errato, Supabase rifiuterà comunque il token. Validare prima evita chiamate API non necessarie e fornisce messaggi di errore più chiari.
-
Problemi di Cache dei Token: In alcuni sistemi operativi (soprattutto iOS), Google Sign-In SDK può memorizzare i token per migliorare le prestazioni. Quando viene restituito un token memorizzato, il token memorizzato potrebbe essere stato generato con un diverso nonce (o nessun nonce), causando che Supabase rifiuti il token con un errore di “mismatch nonce”. Validando prima di inviare a Supabase, possiamo rilevare questo problema in anticipo e riprovare automaticamente con un token fresco.
-
Security (iOS): Sulla piattaforma iOS, la validazione assicura che il token sia stato emesso per i tuoi ID Client Google specifici, prevenendo potenziali problemi di sicurezza dall'utilizzo di token destinati ad altre applicazioni.
-
Miglioramento degli Errori: Rilevando gli errori prima di Supabase consente la logica di riprova automatica, essenziale per gestire trasparentemente le problematiche di caching iOS.
Se la validazione fallisce, la funzione si autonoma:
- Logga fuori da Google (elimina i token memorizzati - critico su iOS)
- Riprova l'autenticazione una volta (forza la generazione di un token fresco con nonce corretto)
- Se anche la riprova fallisce, restituisce un errore
4. Accesso a Supabase
Sezione intitolata “4. Accesso a Supabase”Infine, il token validato viene inviato a Supabase:
const { data, error } = await supabase.auth.signInWithIdToken({ provider: 'google', token: googleResponse.idToken, nonce: rawNonce, // Pass the raw (unhashed) nonce});Riferimento completo Code
Sottosezione intitolata “Riferimento completo Code”La completa implementazione è disponibile nel file dell'applicazione di esempio supabaseAuthUtils.ts che include:
getUrlSafeNonce()- Genera un nonce sicuro per URLsha256Hash()- Cifra una stringa con SHA-256getNonce()- Genera coppia noncedecodeJWT()- Decodifica token JWTvalidateJWTToken()- Valida l'audience e il nonce JWTauthenticateWithGoogleSupabase()- Funzione di autenticazione principale con ritentativo automatico
Esempi di file aggiuntivi
Sezione intitolata “Esempi di file aggiuntivi”- SupabasePage.tsx - Componente di esempio con gestione del redirect (Web)
- SupabaseCreateAccountPage.tsx - Pagina di esempio per la registrazione
Passaggi successivi
Sezione intitolata “Passaggi successivi”Per favore procedere al guide di configurazione specifica per la piattaforma di destinazione:
Continua da Supabase Google Login - Configurazione Generale
Sezione intitolata “Continua da Supabase Google Login - Configurazione Generale”Se stai utilizzando Supabase Google Login - Configurazione Generale per pianificare l'autenticazione e le flussi di account, connettilo con Utilizza @capgo/capacitor-login-social per la capacità nativa in Utilizza @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 @capgo/capacitor-biometrica-nativa per i dettagli di implementazione in @capgo/capacitor-native-biometric, e Autenticazione a due fattori per i dettagli di implementazione in Autenticazione a due fattori.