Se utilizzi Accedi con Google su un'app o un sito che comunica con un server di backend, potresti dover identificare l'utente che ha eseguito l'accesso sul server. Per farlo in sicurezza, dopo che un utente ha eseguito l'accesso, invia il token ID dell'utente al tuo server utilizzando HTTPS. Quindi, sul server, verifica l'integrità del token ID e utilizza le informazioni utente contenute nel token per stabilire una sessione o creare un nuovo account.
Invia il token ID al tuo server
Dopo che un utente ha eseguito l'accesso, recupera il token ID dell'utente:
Swift
GIDSignIn.sharedInstance.signIn(withPresenting: self) { signInResult, error in guard error == nil else { return } guard let signInResult = signInResult else { return } signInResult.user.refreshTokensIfNeeded { user, error in guard error == nil else { return } guard let user = user else { return } let idToken = user.idToken // Send ID token to backend (example below). } }
Objective-C
[GIDSignIn.sharedInstance signInWithPresentingViewController:self completion:^(GIDSignInResult * _Nullable signInResult, NSError * _Nullable error) { if (error) { return; } if (signInResult == nil) { return; } [signInResult.user refreshTokensIfNeededWithCompletion:^(GIDGoogleUser * _Nullable user, NSError * _Nullable error) { if (error) { return; } if (user == nil) { return; } NSString *idToken = user.idToken; // Send ID token to backend (example below). }]; }];
Quindi, invia il token ID al tuo server con una richiesta POST HTTPS:
Swift
func tokenSignInExample(idToken: String) { guard let authData = try? JSONEncoder().encode(["idToken": idToken]) else { return } let url = URL(string: "https://yourbackend.example.com/tokensignin")! var request = URLRequest(url: url) request.httpMethod = "POST" request.setValue("application/json", forHTTPHeaderField: "Content-Type") let task = URLSession.shared.uploadTask(with: request, from: authData) { data, response, error in // Handle response from your backend. } task.resume() }
Objective-C
NSString *signinEndpoint = @"https://yourbackend.example.com/tokensignin"; NSDictionary *params = @{@"idtoken": idToken}; NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:signinEndpoint]; [request setValue:@"application/x-www-form-urlencoded" forHTTPHeaderField:@"Content-Type"]; [request setHTTPMethod:@"POST"]; [request setHTTPBody:[self httpBodyForParamsDictionary:params]]; NSOperationQueue *queue = [[NSOperationQueue alloc] init]; [NSURLConnection sendAsynchronousRequest:request queue:queue completionHandler:^(NSURLResponse *response, NSData *data, NSError *error) { if (error) { NSLog(@"Error: %@", error.localizedDescription); } else { NSLog(@"Signed in as %@", data.bytes); } }];
Verifica l'integrità del token ID
Dopo aver ricevuto il token ID tramite HTTPS POST, devi verificarne l'integrità.
Per verificare che il token sia valido, assicurati che: vengono soddisfatti i seguenti criteri:
- Il token ID sia stato firmato correttamente da Google. Utilizza le chiavi pubbliche di Google
(disponibile in
JWK o
PEM)
per verificare la firma del token. Queste chiavi vengono ruotate regolarmente, esaminare
l'intestazione
Cache-Control
nella risposta per determinare quando dovresti recuperarli di nuovo. - Il valore di
aud
nel token ID è uguale a uno dei gli ID cliente. Questo controllo è necessario per evitare token ID emessi da un utente malintenzionato dell'app utilizzata per accedere ai dati relativi allo stesso utente sul server di backend dell'app. - Il valore di
iss
nel token ID è uguale aaccounts.google.com
ohttps://accounts.google.com
. - La data di scadenza (
exp
) del token ID non è trascorsa. - Se devi confermare che il token ID rappresenta un account Google Workspace o Cloud
dell'organizzazione, puoi controllare la rivendicazione
hd
, che indica la presenza di dominio dell'utente. Deve essere usato quando limiti l'accesso a una risorsa ai soli membri di determinati domini. L'assenza di questa rivendicazione indica che l'account non appartiene a un Dominio ospitato da Google.
Utilizzando i campi email
, email_verified
e hd
, puoi determinare se
Google ospita un indirizzo email ed è autorevole. Nei casi in cui Google è autorevole,
è noto per essere il legittimo proprietario dell'account e puoi saltare l'uso della password
metodi di verifica.
Casi in cui Google è autorevole:
email
ha un suffisso@gmail.com
, questo è un account Gmail.email_verified
è true ehd
è impostato, questo è un account G Suite.
Gli utenti possono registrarsi per creare Account Google senza utilizzare Gmail o G Suite. Quando
email
non contiene un suffisso @gmail.com
e hd
non è presente; Google non
autoritativi e con password o altri metodi di verifica per verificare
per l'utente. Il valore email_verified
può anche essere vero perché Google ha verificato inizialmente il valore
all'utente quando è stato creato l'account Google, ma la proprietà della terza parte
l'account email potrebbe essere cambiato da allora.
Anziché scrivere il tuo codice per eseguire questi passaggi di verifica, ti consigliamo
consigliamo di utilizzare una libreria client API di Google per la tua piattaforma o un
nella libreria JWT. Per lo sviluppo e il debug, puoi chiamare il nostro tokeninfo
endpoint di convalida.
Utilizzo di una libreria client dell'API di Google
Utilizzi una delle librerie client delle API di Google (ad es. Java Node.js, PHP, Python) è il metodo consigliato per convalidare i token ID Google in un ambiente di produzione.
Per convalidare un token ID in Java, utilizza la GoogleIdTokenVerifier. Ad esempio:
import com.google.api.client.googleapis.auth.oauth2.GoogleIdToken; import com.google.api.client.googleapis.auth.oauth2.GoogleIdToken.Payload; import com.google.api.client.googleapis.auth.oauth2.GoogleIdTokenVerifier; ... GoogleIdTokenVerifier verifier = new GoogleIdTokenVerifier.Builder(transport, jsonFactory) // Specify the CLIENT_ID of the app that accesses the backend: .setAudience(Collections.singletonList(CLIENT_ID)) // Or, if multiple clients access the backend: //.setAudience(Arrays.asList(CLIENT_ID_1, CLIENT_ID_2, CLIENT_ID_3)) .build(); // (Receive idTokenString by HTTPS POST) GoogleIdToken idToken = verifier.verify(idTokenString); if (idToken != null) { Payload payload = idToken.getPayload(); // Print user identifier String userId = payload.getSubject(); System.out.println("User ID: " + userId); // Get profile information from payload String email = payload.getEmail(); boolean emailVerified = Boolean.valueOf(payload.getEmailVerified()); String name = (String) payload.get("name"); String pictureUrl = (String) payload.get("picture"); String locale = (String) payload.get("locale"); String familyName = (String) payload.get("family_name"); String givenName = (String) payload.get("given_name"); // Use or store profile information // ... } else { System.out.println("Invalid ID token."); }
Il metodo GoogleIdTokenVerifier.verify()
verifica il JWT
la rivendicazione aud
, la rivendicazione iss
e la
Rivendicazione di exp
.
Se devi confermare che il token ID rappresenta un account Google Workspace o Cloud
account dell'organizzazione, puoi verificare la rivendicazione hd
controllando il nome di dominio
restituito dal metodo Payload.getHostedDomain()
. Il dominio del
Il reclamo email
non è sufficiente per garantire che l'account sia gestito da un dominio
o organizzazione.
Per convalidare un token ID in Node.js, utilizza la libreria di autenticazione di Google per Node.js. Installa la libreria:
npm install google-auth-library --saveQuindi, chiama la funzione
verifyIdToken()
. Ad esempio:
const {OAuth2Client} = require('google-auth-library'); const client = new OAuth2Client(); async function verify() { const ticket = await client.verifyIdToken({ idToken: token, audience: CLIENT_ID, // Specify the CLIENT_ID of the app that accesses the backend // Or, if multiple clients access the backend: //[CLIENT_ID_1, CLIENT_ID_2, CLIENT_ID_3] }); const payload = ticket.getPayload(); const userid = payload['sub']; // If the request specified a Google Workspace domain: // const domain = payload['hd']; } verify().catch(console.error);
La funzione verifyIdToken
verifica
la firma JWT, la dichiarazione aud
, la dichiarazione exp
,
e la rivendicazione iss
.
Se devi confermare che il token ID rappresenta un account Google Workspace o Cloud
dell'organizzazione, puoi controllare la rivendicazione hd
, che indica la presenza di
dominio dell'utente. Deve essere utilizzato quando limiti l'accesso a una risorsa ai soli membri
di determinati domini. L'assenza di questa rivendicazione indica che l'account non appartiene a
un dominio ospitato da Google.
Per convalidare un token ID in PHP, utilizza la libreria client dell'API di Google per PHP. Installa la libreria (ad esempio utilizzando Composer):
composer require google/apiclientQuindi, chiama la funzione
verifyIdToken()
. Ad esempio:
require_once 'vendor/autoload.php'; // Get $id_token via HTTPS POST. $client = new Google_Client(['client_id' => $CLIENT_ID]); // Specify the CLIENT_ID of the app that accesses the backend $payload = $client->verifyIdToken($id_token); if ($payload) { $userid = $payload['sub']; // If the request specified a Google Workspace domain //$domain = $payload['hd']; } else { // Invalid ID token }
La funzione verifyIdToken
verifica
la firma JWT, la dichiarazione aud
, la dichiarazione exp
,
e la rivendicazione iss
.
Se devi confermare che il token ID rappresenta un account Google Workspace o Cloud
dell'organizzazione, puoi controllare la rivendicazione hd
, che indica la presenza di
dominio dell'utente. Deve essere utilizzato quando limiti l'accesso a una risorsa ai soli membri
di determinati domini. L'assenza di questa rivendicazione indica che l'account non appartiene a
un dominio ospitato da Google.
Per convalidare un token ID in Python, utilizza la classe verify_oauth2_token personalizzata. Ad esempio:
from google.oauth2 import id_token from google.auth.transport import requests # (Receive token by HTTPS POST) # ... try: # Specify the CLIENT_ID of the app that accesses the backend: idinfo = id_token.verify_oauth2_token(token, requests.Request(), CLIENT_ID) # Or, if multiple clients access the backend server: # idinfo = id_token.verify_oauth2_token(token, requests.Request()) # if idinfo['aud'] not in [CLIENT_ID_1, CLIENT_ID_2, CLIENT_ID_3]: # raise ValueError('Could not verify audience.') # If the request specified a Google Workspace domain # if idinfo['hd'] != DOMAIN_NAME: # raise ValueError('Wrong domain name.') # ID token is valid. Get the user's Google Account ID from the decoded token. userid = idinfo['sub'] except ValueError: # Invalid token pass
La funzione verify_oauth2_token
verifica il JWT
firma, la rivendicazione aud
e la rivendicazione exp
.
Devi anche verificare il hd
dichiarativa (se applicabile) esaminando l'oggetto
Resi di verify_oauth2_token
. Se più client accedono
server di backend, inoltre verifica manualmente l'attestazione aud
.
Chiamata all'endpoint tokeninfo
Un modo semplice per convalidare la firma di un token ID per il debug è:
usa l'endpoint tokeninfo
. La chiamata a questo endpoint prevede un
richiesta di rete aggiuntiva che esegue la maggior parte della convalida, mentre
la convalida e l’estrazione del payload nel tuo codice. Non è adatto per l'uso in produzione
poiché le richieste potrebbero essere limitate o comunque soggette a errori intermittenti.
Per convalidare un token ID utilizzando l'endpoint tokeninfo
, crea un protocollo HTTPS
POST o GET all'endpoint e trasmetti il token ID
id_token
.
Ad esempio, per convalidare il token "XYZ123", effettua la seguente richiesta GET:
https://oauth2.googleapis.com/tokeninfo?id_token=XYZ123
Se il token è firmato correttamente e iss
e exp
che le attestazioni hanno i valori previsti, si riceverà una risposta HTTP 200, in cui il corpo
contiene le attestazioni dei token ID in formato JSON.
Ecco un esempio di risposta:
{ // These six fields are included in all Google ID Tokens. "iss": "https://accounts.google.com", "sub": "110169484474386276334", "azp": "1008719970978-hb24n2dstb40o45d4feuo2ukqmcc6381.apps.googleusercontent.com", "aud": "1008719970978-hb24n2dstb40o45d4feuo2ukqmcc6381.apps.googleusercontent.com", "iat": "1433978353", "exp": "1433981953", // These seven fields are only included when the user has granted the "profile" and // "email" OAuth scopes to the application. "email": "testuser@gmail.com", "email_verified": "true", "name" : "Test User", "picture": "https://lh4.googleusercontent.com/-kYgzyAWpZzJ/ABCDEFGHI/AAAJKLMNOP/tIXL9Ir44LE/s99-c/photo.jpg", "given_name": "Test", "family_name": "User", "locale": "en" }
Se devi verificare che il token ID rappresenti un account Google Workspace, puoi controllare
la rivendicazione hd
, che indica il dominio ospitato dell'utente. Deve essere utilizzata quando
limitare l'accesso a una risorsa ai soli membri di determinati domini. L'assenza di questa dichiarazione
indica che l'account non appartiene a un dominio ospitato da Google Workspace.
Creare un account o una sessione
Dopo aver verificato il token, controlla se l'utente si trova già nel tuo database utenti. In tal caso, stabilisci una sessione autenticata per l'utente. Se l'utente non è ancora presente nel tuo database utenti, crea un nuovo record utente dalle informazioni contenute nel payload del token ID e stabilisci una sessione per l'utente. Puoi richiedere all'utente eventuali informazioni del profilo aggiuntive di cui hai bisogno quando rilevi un nuovo utente nella tua app.
Proteggere gli account degli utenti con la Protezione su più account
Quando ti affidi a Google per accedere a un utente, beneficerai automaticamente di tutte le funzionalità e l'infrastruttura di sicurezza che Google ha creato per salvaguardare i dati dell'utente. Tuttavia, nell'improbabile caso che l'Account Google dell'utente venga compromesso o si verifichi un altro evento di sicurezza significativo, anche la tua app può essere vulnerabile agli attacchi. Per proteggere meglio i tuoi account dai principali eventi di sicurezza, utilizza la Protezione su più account per ricevere avvisi di sicurezza da Google. Quando ricevi questi eventi, hai visibilità sulle modifiche importanti apportate alla sicurezza dell'Account Google dell'utente e puoi quindi intervenire sul servizio per proteggere i tuoi account.