Configurer le SSO natif vers le Web
Le SSO natif vers le Web prend en charge les SDK suivants : Auth0 Android SDK, Auth0 Swift SDK et Auth0 React Native SDK.La prise en charge du SSO natif vers le Web est offerte dans les outils suivants : Auth0 Deploy CLI, Auth0 Terraform Provider et Auth0 CLI.Le SSO natif vers le Web prend en charge tout flux d’authentification qui renvoie un jeton d’actualisation, comme Resource Owner Password Flow et Authorization Code Flow with Proof Key for Code Exchange.
Créer et gérer des jetons de transfert de session
- Créer et gérer des
session_transfer_tokens - Créer des sessions dans un navigateur web au moyen de cookies ou d’un paramètre d’URL
- Lier la session à l’appareil d’un utilisateur à l’aide d’une adresse IP ou d’un ASN
PATCH au point de terminaison Update a Client. Pour créer une nouvelle application, effectuez un appel POST au point de terminaison Create a Client :
Configurer les applications natives
-
Mettez à jour votre application native à l’aide de :
- Accédez à Dashboard > Applications :
- Sélectionnez ou créez votre application.
- Sélectionnez l’onglet Settings.
- Sous Session Transfer, activez Allow Native to Web SSO.
- Sélectionnez Require Cascade Revocation pour révoquer automatiquement la session de l’application Web et les jetons associés.
- Sélectionnez Save pour mettre à jour votre application.

- Mettez à jour votre application native à l’aide de votre pour la Management API avec le point de terminaison Update a Client :
- Mettez à jour votre application native avec Auth0 CLI :
Configurer les applications Web
-
Mettez à jour votre application Web à l’aide d’Auth0 Dashboard :
- Accédez à Dashboard > Applications :
- Sélectionnez ou créez votre application Web.
- Sélectionnez l’onglet Settings.
- Sous Session Transfer, activez Native to Web SSO Methods.
- Sélectionnez Cookie Authentication et Query Authentication.
- Activez Device Binding Method en choisissant None, ASN Binding ou IP Address Binding.
- Activez Allow Refresh Token Requests pour émettre de nouveaux jetons d’actualisation après un transfert de session.
- Sélectionnez Use online refresh tokens.
- Sélectionnez Save pour mettre à jour votre application Web.

- Mettez à jour votre application Web à l’aide du jeton d’accès de la Management API avec le point de terminaison Mettre à jour une application :
- Mettez à jour votre application web à l’aide d’Auth0 CLI :
Implémenter le SSO natif vers le Web
-
Si
allow_refresh_tokenest désactivé dans l’application, mais que l’application demandeoffline_access, Auth0 n’émet pas derefresh_token, mais l’authentification fonctionne quand même. -
Si la rotation des Jetons d’actualisation est activée, Auth0 renvoie un nouveau
refresh_tokendans l’appel d’échange de jeton. L’échange du Jeton d’actualisation doit avoir lieu immédiatement avant que votre code n’ouvre l’application Web.
Dans votre application native
Étape 1 : Échanger un jeton d’actualisation contre un jeton de transfert de session
- Échangez un jeton d’actualisation contre un jeton de transfert de session à l’aide des SDK Swift, Android ou React Native :
- SDK Swift
- SDK Android
- SDK React Native
- Échangez un jeton d’actualisation contre un jeton de transfert de session à l’aide d’HTTP :
Ces exemples utilisent des espaces réservés pour les valeurs dynamiques. Remplacez-les par votre domaine Auth0, votre client_id et un refresh_token existant.
Si la rotation des jetons d’actualisation est activée, l’échange renverra également un jeton d’actualisation.Si vous avez demandé un ID Token pendant l’authentification, cet appel renverra aussi un ID Token.
session_transfer_token à votre application web, selon les allowed_authentication_methods configurées.
Si votre application web qui utilise WebView ou un navigateur prend en charge l’injection de cookies, vous pouvez configurer votre application native pour :
- Ajouter le session_transfer_token dans un cookie.
- Ouvrir l’application web au moyen de WebView ou d’un navigateur.
- Connecter l’application web à votre locataire Auth0 ou à votre . Comme le
session_transfer_tokenest inclus dans le cookie, l’utilisateur n’a pas à s’authentifier avec le premier facteur.
Option 2 : Envoyer le session_transfer_token en tant que paramètre d’URL
- Ajouter le session_transfer_token en tant que paramètre d’URL.
- Ouvrir l’application web à l’aide de WebView ou d’un navigateur.
- Ouvrir une session dans l’application web en ajoutant le
session_transfer_tokencomme paramètre d’URL au point de terminaison /authorize. Le locataire Auth0 authentifie l’utilisateur sans exiger d’authentification du premier facteur, puisque le session_transfer_token est valide et approuvé.
Dans votre application web
Lorsque le jeton de transfert de session est envoyé sous forme de cookie, aucune configuration supplémentaire n’est requise, puisque le navigateur envoie le cookie dans la requête au point de terminaison
/authorize.Option 1 : Ajouter le jeton de transfert de session à la requête de votre application web
/authorize lorsque le paramètre d’URL session_transfer_token est transmis.
Option 2 : Ajouter le jeton de transfert de session aux applications web à l’aide des SDK Auth0
session_transfer_token dans la requête adressée au point de terminaison /authorize.
Vous trouverez ci-dessous des exemples d’applications web utilisant les SDK Auth0 pour transmettre le session_transfer_token dans la requête adressée au point de terminaison /authorize :
Node (Express.js)
session_transfer_token.
javascript
SDK SPA d’Auth0 (@auth0/auth0-spa-js)
session_transfer_token à loginWithRedirect() dans authorizationParams.
typescript
SDK React d’Auth0 (@auth0/auth0-react)
loginWithRedirect du hook useAuth0 pour transmettre le session_transfer_token.
typescript
SAML et WS-Federation
session_transfer_token en tant que paramètre d’URL au point de terminaison Auth0 /authorize, et le redirect_uri correspond à l’URL de connexion SAML ou WS-Fed.
SSO natif vers le Web avec les Organisations
Lorsque vous utilisez les Organisations avec le SSO natif vers le Web, le paramètre
organization de la requête /authorize de l’application Web doit correspondre à l’organisation associée au jeton de transfert de session. En cas de non-correspondance, l’authentification échouera et l’utilisateur devra se reconnecter.- Authentifiez l’utilisateur dans votre application native auprès d’une organisation :
javascript
- Lors de la redirection vers l’application web, incluez la même organisation dans la requête
/authorize:
bash
/authorize ne correspond pas à l’organisation dans le jeton de transfert de session, le jeton de transfert de session est rejeté et l’utilisateur est redirigé vers la page de connexion pour se réauthentifier. Un avertissement est consigné dans les journaux de votre locataire avec la description d’événement “Échec de l’authentification unique : non-correspondance de l’organisation détectée dans le jeton de transfert de session.”
Jeton de transfert de session avec Actions
session_transfer_token avec Actions vous permet de configurer des fonctionnalités de détection et de réponse aux risques après l’authentification afin de renforcer la protection des utilisateurs.
À cette fin, l’objet d’Action post-login event.session_transfer_token fournit des informations pertinentes, notamment le client_id unique, le scope, des informations sur la request, comme ip, asn, user_agent, ainsi que des informations geoip, comme cityName et countryCode, entre autres. Pour en savoir plus, consultez Déclencheurs d’Actions : post-login - objet Event.
Le code d’Action ci-dessous vous permet de refuser dynamiquement une transaction en fonction des informations de géolocalisation :
javascript
Accéder aux métadonnées du jeton d’actualisation parent
session_transfer_token des informations contextuelles recueillies dans l’application native (comme l’intégrité de l’appareil, des signaux de risque ou un contexte personnalisé).
Auth0 expose ces informations dans les Actions Post Login par l’intermédiaire de l’objet event.session.session_transfer.parent_refresh_token.metadata. Cela permet une propagation sécurisée et normalisée des métadonnées entre les plateformes.
Exemple de cas d’utilisation : Une application mobile recueille des données de risque (score de l’appareil, emplacement, etc.) et les stocke dans les métadonnées du jeton d’actualisation. Lorsque l’application native lance un flux SSO natif vers le Web, ces métadonnées sont automatiquement accessibles dans la session Web correspondante via Actions.
javascript
Surveillance
Journaux d’échange de jetons
sertft: Échange réussi du Jeton d’actualisation. Ce journal correspond à un échange SSO du natif vers le Web lorsque le champaudienceest"audience":"urn:$auth0Domain:session_transfer"fertft: Échec de l’échange du Jeton d’actualisation. Ce journal correspond à un échange SSO du natif vers le Web lorsque le champaudienceest"audience": "urn:$auth0Domain:session_transfer"
Journaux d’avertissement de validation du transfert de session
w) lorsque la validation du jeton de transfert de session échoue lors de la requête /authorize. Ces journaux vous aident à résoudre les problèmes de SSO du natif vers le Web :
| Description de l’événement | Cause |
|---|---|
Single Sign-On failed: Session Transfer Token not found or expired. This may indicate token reuse or expiration. | Le jeton de transfert de session est introuvable, a déjà été utilisé ou a expiré (les jetons sont à usage unique et expirent après 1 minute). |
Single Sign-On failed: Session Transfer Token device binding validation failed due to IP/ASN mismatch. | L’adresse IP ou l’ASN de la requête web ne correspond pas à la liaison de l’appareil configurée pour le jeton de transfert de session. |
Single Sign-On failed: Session Transfer Token organization mismatch detected. | Le paramètre organization dans la requête /authorize ne correspond pas à l’organisation du jeton de transfert de session. |
Single Sign-On failed: Session Transfer Token user mismatch detected. | Une session Auth0 préexistante appartient à un utilisateur différent de celui associé au jeton de transfert de session. |
Single Sign-On failed: Parent refresh token not found. Session Transfer Token won't be used for session establishment. | Le jeton d’actualisation parent utilisé pour créer le jeton de transfert de session a été révoqué ou supprimé. |