Configurazione di accesso Google
Copia una riga di configurazione con i passaggi di installazione e la guida markdown completa per questo plugin.
Introduzione
Sezione intitolata “Introduzione”In questo manuale, imparerai a configurare l'accesso Google con Capgo Social Login. Avrai bisogno delle seguenti informazioni per configurare l'accesso Google:
- Un account Google
Configurazione generale
Sezione intitolata “Configurazione generale”In questa parte, configurerai la schermata di accesso visualizzata da Google.
- Per favore, vai a console.cloud.google.com
- Clicca sul selettore del progetto
- Se non hai già un progetto, per favore crea un nuovo progetto.
- Clicca su
New project
- Nomi il tuo progetto e clicca
Create
- Assicurati di essere sul progetto giusto
- Clicca su
- Inizia a configurare il
OAuth consent screen-
Clicca sul campo di ricerca
-
Cerca
OAuth consent screene clicca su di esso
-
Configura lo schermo di consenso
Clicca su
create
-
- Inserisci le informazioni sulla tua app
-
Iniziamo con la sezione
App Information
- Inserisci il tuo
App Name - Inserisci il
user support email
-
Puoi CAN aggiungi il logo dell'applicazione.
-
Tu DEVI configurare la
App domain
-
DEVI fornire l'indirizzo email del sviluppatore Sezione di contatto del sviluppatore con campo email
-
Salva e continua
save and continue
- Inserisci il tuo
-
- Aggiungi o rimuovi scope
-
Clicca su
add or remove scopes
-
Seleziona i seguenti ambiti e clicca
update
-
Clicca
save and continue
-
- Aggiungi un utente di prova
- Clicca su
add users
- Inserisci la tua email Google, clicca invio e clicca
add
- Clicca
save and continue
- Clicca su
- Clicca
back to dashboard
- Invia la tua app per la verifica
Differenze tra accesso online e accesso offline
Sottosezione intitolata “Differenze tra accesso online e accesso offline”Esistono diverse modalità per utilizzare Google Login con Capacitor. Ecco una tabella che riassume le differenze tra le due:
| Accesso online | Accesso offline | |
|---|---|---|
| Richiede un backend | ❌ | ✅ |
| Token di accesso a lungo valido | ❌ | ✅ |
| Configurazione facile | ✅ | ❌ |
Se ancora non sai quale scegliere, considera i seguenti scenari:
-
Vuoi che l'utente si accedi, subito dopo ti occuperai di emettergli un JWT personalizzato. La tua app NON chiamerà le API di Google
In questo caso, scegli l'accesso online.
-
La tua app chiamerà alcune API di Google dal client, ma mai dal backend
In questo caso, scegli l'accesso online
-
La tua app chiamerà alcune API di Google dal backend, ma solo quando l'utente sta utilizzando attivamente l'app
In questo caso, scegli l'accesso online
-
La tua app controlla periodicamente il calendario dell'utente, anche quando non sta utilizzando l'app attivamente
In questo caso, scegli l'accesso offline
Un esempio di backend per l'accesso online
Sezione intitolata “Un esempio di backend per l'accesso online”In questa parte del tutorial, mostrerò come validare l'utente sul tuo backend
Questo esempio sarà molto semplice e si baserà sulle seguenti tecnologie:
Potrai trovare il code per questo esempio qui
Come puoi vedere:
L'idea è piuttosto semplice. Inviare una richiesta semplice a GET e questo ti restituisce se il token è valido o no e se lo è, ti dà l'indirizzo email dell'utente. Inoltre, ti dà alcune altre informazioni sul token dell'utente https://www.googleapis.com/oauth2/v3/tokeninfo Google OAuth Playground che mostra le informazioni di risposta del token con dettagli dell'utente
Se desideri effettivamente chiamare Google __CAPGO_KEEP_0__’, ti consiglio fortemente di guardare a
If you do want to call Google API’s, I would strongly recommend looking at . Da lì puoi facilmente vedere quali API puoi chiamare.L'accesso offline con il tuo backend
Sezione intitolata “L'accesso offline con il tuo backend”’]}
targetLanguagePer utilizzare l'accesso offline avrai bisogno delle seguenti cose:
- Un server HTTP
In questo esempio, utilizzo le seguenti tecnologie per fornire l'accesso offline nell'app:
-
LowDb (una semplice database)
Il code per questo esempio può essere trovato qui
Per quanto riguarda il client code, ha questo aspetto:
import { Capacitor } from '@capacitor/core';import { GoogleLoginOfflineResponse, SocialLogin } from '@capgo/capacitor-social-login';import { usePopoutStore } from '@/popoutStore'; // <-- specific to my app
const baseURL = "[redacted]";
async function fullLogin() { await SocialLogin.initialize({ google: { webClientId: '[redacted]', iOSClientId: '[redacted]', iOSServerClientId: 'The same value as webClientId', mode: 'offline' // <-- important } }) const response = await SocialLogin.login({ provider: 'google', options: { forceRefreshToken: true // <-- important } })
if (response.provider === 'google') { const result = response.result as GoogleLoginOfflineResponse const res = await fetch(`${baseURL}/auth/google_offline`, { headers: { "Content-Type": "application/json" }, body: JSON.stringify({ serverAuthCode: result.serverAuthCode, platform: Capacitor.getPlatform() }), method: "POST" })
if (res.status !== 200) { popoutStore.popout("Full google login failed", "check console"); return }
const { jwt } = await res.json(); const userinfo = await fetch(`${baseURL}/auth/get_google_user`, { headers: { Authorization: `Bearer ${jwt}` } }) if (userinfo.status !== 200) { popoutStore.popout("Full google (userinfo) login failed", "check console"); return } popoutStore.popout("userinfo res", await userinfo.text()); }}Nota cosa manca qui: non c'è SocialLogin.refresh() chiamata nell'app. Questo è intenzionale. In modalità offline di Google, il refresh avviene dopo che il tuo backend scambia serverAuthCode e memorizza il token di refresh in modo sicuro.
Continua da Google Login Setup
Se stai utilizzandoGoogle Login Setup per pianificare l'autenticazione e le flussi di account, connettilo con Utilizza @__CAPGO_KEEP_0__/__CAPGO_KEEP_1__-social-login per la capacità nativa in Utilizza @capgo/capacitor-social-login, Utilizza @capgo/capacitor-social-login @capgo/capacitor-social-login per i dettagli di implementazione in @capgo/capacitor-login-social @capgo/capacitor-passkey per i dettagli di implementazione in @capgo/capacitor-passkey @capgo/capacitor-biometric-nativo per i dettagli di implementazione in @capgo/capacitor-biometric-nativo, e Autenticazione a due fattori per i dettagli di implementazione in Autenticazione a due fattori.