Authorization. Comme l’API backend ne reçoit aucun jeton d’actualisation émis pour la SPA, elle ne peut pas utiliser l’échange de jeton d’actualisation pour accéder à Token Vault et appeler des API externes.
À la place, l’API backend peut échanger le jeton d’accès Auth0 reçu de la SPA contre le jeton d’accès d’un fournisseur externe, autrement dit effectuer un échange de jetons d’accès. Ce processus permet de protéger les informations d’identification externes sensibles sur le backend.
Dans l’échange de jetons d’accès d’Auth0, l’API backend agit à la fois comme application et comme serveur de ressources :
- Application : utilise ses propres informations d’identification pour effectuer de façon sécurisée l’échange de jetons d’accès avec le serveur d’autorisation Auth0. Dans Auth0, vous créez un Custom API Client avec le même identifiant que l’API backend. L’API backend transmet les informations d’identification du Custom API Client pour effectuer de façon sécurisée l’échange de jetons d’accès avec le serveur d’autorisation Auth0.
- Serveur de ressources : met l’API backend à la disposition de la SPA et valide le jeton d’accès Auth0.
Cas d’utilisation
- Une API backend : un utilisateur interagit avec une SPA, qui appelle ensuite une API backend pour échanger un jeton d’accès Auth0 contre un jeton d’accès d’un fournisseur externe auprès du serveur d’autorisation Auth0.
- Architecture de microservices : des services backend, comme des serveurs MCP ou d’autres serveurs de ressources OAuth 2.0, qui doivent échanger des jetons d’accès pour accéder à des API externes.
Comment ça fonctionne

Prérequis
Étape 2 : la SPA appelle l’API backend avec un jeton d’accès Auth0
Authorization. L’API backend valide le jeton d’accès Auth0 en vérifiant les éléments suivants :
- Signature : vérifie la signature du jeton à l’aide de la clé publique d’Auth0. Cela confirme qu’Auth0 a émis le jeton d’accès.
- Émetteur : vérifie la revendication
issdans la charge utile du jeton pour confirmer que le jeton a été émis par votre locataire Auth0. - Audience : vérifie la revendication
audpour s’assurer qu’elle correspond à l’identifiant unique de l’API backend elle-même. Cela confirme que le jeton a bien été émis pour ce serveur de ressources. - Expiration : valide la revendication
exppour s’assurer que le jeton est toujours valide et n’a pas expiré. - Scopes : vérifie la revendication
scopepour déterminer quelles autorisations ont été accordées à l’utilisateur.
Étape 3 : L’API backend effectue l’échange de jetons d’accès
POST au point de terminaison /oauth/token.
Dans la requête de jeton, l’API backend :
- Transmet les informations d’identification de l’API backend (celles du Custom API Client) au serveur d’autorisation Auth0 pour s’authentifier.
- Échange un jeton d’accès Auth0 contre un jeton d’accès Google.
| Paramètre | Description |
|---|---|
grant_type | Le type d’octroi. Pour Token Vault, définissez-le sur urn:auth0:params:oauth:grant-type:token-exchange:federated-connection-access-token |
client_id | ID de l’application |
client_secret | Secret client. Remarque : Vous pouvez utiliser n’importe quelle méthode d’authentification d’application pour obtenir le jeton d’accès d’un fournisseur externe. |
subject_token_type | Le type de jeton du sujet. Pour l’échange de jetons d’accès, définissez-le sur le jeton d’accès : urn:ietf:params:oauth:token-type:access_token. |
subject_token | Le jeton d’accès Auth0 que le serveur d’autorisation Auth0 valide pour identifier l’utilisateur. |
requested_token_type | Le type de jeton demandé. Pour Token Vault, définissez-le sur le jeton d’accès du fournisseur externe ou sur http://auth0.com/oauth/token-type/federated-connection-access-token |
connection | Le nom de la connexion, dans ce cas-ci, google-oauth2. |
login_hint | (Facultatif) Utilisez login_hint uniquement si l’utilisateur a plusieurs comptes provenant de la même connexion, par exemple un compte Google professionnel et un compte Google personnel. Lorsque vous transmettez une valeur pour login_hint pendant l’échange de jeton, vous indiquez explicitement lequel des comptes liés de l’utilisateur est visé par la demande. |
- Auth0 vérifie que l’application qui effectue la demande d’échange de jetons d’accès est liée à l’API backend identifiée par l’
audiencedu jeton d’accès. - Auth0 vérifie si le tableau
connected_accountsdu profil de l’utilisateur contient un compte d’utilisateur avec le nom de la connexion transmis dans la demande d’autorisation. - Si la demande d’autorisation contient
login_hint, Auth0 recherche une identité correspondant à la fois au nom de la connexion et aulogin_hint. - Si Auth0 ne trouve pas l’utilisateur, il renvoie un code d’état
401accompagné d’un message d’erreur.