Questa pagina descrive come Identity-Aware Proxy (IAP) gestisce una richiesta con una sessione scaduta e come assicurarsi che le richieste di app AJAX e le richieste WebSocket vadano a buon fine.
Flusso della sessione IAP
Quando si utilizza il flusso di accesso IAP standard, l'utente riceve un cookie di sessione che fa riferimento alla sua sessione di accesso Google. IAP utilizza questo cookie per confermare che l'utente ha ancora eseguito l'accesso. L'IAP richiede all'utente di accedere prima di accedere a un'app protetta da IAP.
Le sessioni di IAP vengono aggiornate periodicamente. Tuttavia, se l'utente utilizza un Account Google per accedere, le sessioni di IAP sono collegate anche alla sessione di accesso di Google dell'utente. In questo caso, l'IAP richiede all'utente di accedere di nuovo solo in una delle seguenti situazioni:
- L'utente ha eseguito la disconnessione dal proprio account
- Il suo account è stato sospeso
- L'account richiede la reimpostazione della password
Se un utente non ha eseguito l'accesso, IAP rileva una variazione dello stato dell'Account Google entro un paio di minuti. Una volta rilevato, IAP invalida la sessione.
IAP ricontrolla l'autorizzazione di Identity and Access Management (IAM) per tutte le richieste durante le sessioni valide. L'applicazione degli aggiornamenti ai criteri di accesso IAM di un'app protetta da IAP potrebbe richiedere alcuni minuti.
Scadenza della sessione IAP
Per un flusso di accesso che utilizza un Account Google, la sessione IAP è collegata alla sessione di accesso a Google sottostante e scade solo quando questa sessione scade, indipendentemente dal claim exp
nel JWT inviato nell'intestazione di autorizzazione.
Per l'autenticazione programmatica, IAP rispetta il claim exp
nel JWT inviato nell'intestazione Authorization.
Per il flusso di accesso di Identity Platform, la sessione IAP rimane valida fino a un'ora dopo la disconnessione dell'utente.
Richiesta di conferma dell'accesso per gli Account Google
Il valore loginHint
impostato tramite
IapSettings
deve corrispondere al dominio dell'utente che ha eseguito l'accesso. Se questi valori non corrispondono, viene visualizzata la richiesta di accesso se il cookie IAP è stato cancellato o è scaduto.
Richieste WebSocket
IAP supporta WebSocket solo per le richieste iniziali e non controlla continuamente l'autorizzazione. Quando viene ricevuta una richiesta WebSocket, inizia con una richiesta HTTP Upgrade
.
IAP la valuta come
richiesta HTTP GET
standard. Una volta autorizzata, la richiesta viene passata dal sistema IAP al server, aprendo una connessione persistente. Dopodiché,
IAP non monitora le richieste né aggiorna la sessione.
Risposte alla sessione scadute
IAP restituisce risposte diverse per le sessioni scadute in base al tipo di richiesta.
Richieste non AJAX
Per le richieste non AJAX, l'utente viene reindirizzato al flusso di accesso per aggiornare la sessione. Se l'utente ha ancora eseguito l'accesso, questo reindirizzamento è trasparente.
Richieste AJAX
Chrome e altri browser stanno eliminando i cookie di terze parti. I consigli per effettuare richieste AJAX in questa pagina non funzioneranno se i cookie di terze parti sono disattivati. Tuttavia, i consigli forniti rimarranno funzionali se sia l'origine sia la destinazione delle richieste AJAX provengono dallo stesso sito.
Per istruzioni su come gestire i cookie di terze parti in Chrome, vedi Eliminare, consentire e gestire i cookie in Chrome.
IAP si basa sui cookie per gestire le sessioni utente. Inoltre, si basa su una sequenza di reindirizzamenti per stabilire una sessione nell'ambito di un flusso di accesso. L'impostazione di una sessione non è sempre possibile se l'applicazione utilizza la condivisione delle risorse tra origini (CORS) per effettuare richieste AJAX a un'applicazione protetta da acquisti in-app.
Per effettuare correttamente una richiesta CORS a un'applicazione protetta da IAP, è necessario stabilire una sessione IAP out-of-band. Tieni presente che per una richiesta AJAX che invia una richiesta CORS da
source_domain->target_domain
, dove target_domain
ospita la
applicazione protetta da IAP, deve essere stabilita una sessione su target_domain
. Non è possibile condividere i cookie tra source_domain
e target_domain
.
Una volta stabilita la sessione su target_domain
, lo sviluppatore deve attivare l'invio delle credenziali nella richiesta. Per impostazione predefinita, i metodi JavaScript
non allegheranno i cookie alle richieste. Per attivare le credenziali nella richiesta,
le richieste inviate con un
oggetto
XMLHttpRequest
devono avere la proprietà withCredentials
impostata su true, mentre le richieste inviate
con
Fetch API
devono avere l'opzione credentials
impostata su include
o same-origin
.
La guida riportata di seguito consiglia un pattern per consentire agli sviluppatori web di stabilire e aggiornare correttamente una sessione IAP.
Informazioni sulla risposta IAP
Per le richieste AJAX, IAP restituisce un codice di stato HTTP 401: Unauthorized
. Tieni presente che il rilevamento delle richieste AJAX non può essere eseguito perfettamente. Se
ricevi una risposta con codice di stato 302
anziché 401
alle
richieste AJAX, puoi aggiungere un'intestazione X-Requested-With
con un valore di "XMLHttpRequest"
alle richieste AJAX. In questo modo, IAP viene informato che la richiesta proviene da JavaScript.
Gestione di una risposta AJAX HTTP 401
Per stabilire una sessione IAP dopo che l'applicazione riceve401
HTTP, l'applicazione può aprire una nuova finestra per l'URLtarget_domain
+ ?gcp-iap-mode=DO_SESSION_REFRESH
. Si tratta di un gestore speciale che stabilisce la sessione IAP solo in target_domain
. Se la finestra rimane aperta, continuerà ad aggiornare periodicamente la sessione, chiedendo all'input utente, se necessario.
Se lo desidera, l'utente può scegliere di chiudere la finestra e il gestore dello stato HTTP 401
nel codice dello sviluppatore dovrebbe aprire di nuovo una finestra per l'aggiornamento della sessione, se necessario.
Passaggio 1: modifica il codice dell'app
L'esempio seguente mostra come modificare il codice dell'app per gestire il codice di stato HTTP 401
e fornire all'utente un link per l'aggiornamento della sessione:
Passaggio 2: installa un gestore onclick
Il codice campione riportato di seguito installa un gestore onclick che chiude la finestra dopo l'aggiornamento della sessione: