- Gardez-la secrète. Gardez-la en sécurité : La clé de signature doit être traitée comme toute autre information d’authentification et ne doit être communiquée qu’aux services qui en ont besoin.
- N’ajoutez pas de données sensibles au payload : Les jetons sont signés pour prévenir toute altération et peuvent être décodés facilement. Ajoutez le moins de claims possible au payload afin d’optimiser les performances et la sécurité.
- Définissez une date d’expiration pour les jetons : Techniquement, une fois qu’un jeton est signé, il reste valide indéfiniment, à moins que la clé de signature ne soit modifiée ou qu’une date d’expiration soit explicitement définie. Cela peut entraîner des problèmes; prévoyez donc une stratégie pour faire expirer ou révoquer les jetons.
- Privilégiez HTTPS : N’envoyez pas de jetons sur des connexions autres que HTTPS, car ces requêtes peuvent être interceptées et les jetons compromis.
- Tenez compte de tous vos cas d’utilisation en matière d’autorisation : Il peut être nécessaire d’ajouter un mécanisme secondaire de vérification des jetons pour garantir qu’ils ont bien été générés par votre serveur et ainsi répondre à vos exigences.
- Stockez et réutilisez : Réduisez les allers-retours inutiles qui augmentent la surface d’attaque de votre application, et optimisez les limites de jetons de votre forfait (le cas échéant) en stockant les obtenus auprès du . Au lieu de demander un nouveau jeton, réutilisez le jeton stocké lors des appels ultérieurs jusqu’à son expiration. La façon de stocker les jetons dépend des caractéristiques de votre application : les solutions courantes comprennent les bases de données (pour les applications qui doivent effectuer des appels d’API même en l’absence de session) et les sessions HTTP (pour les applications dont la fenêtre d’activité est limitée à une session interactive). Pour voir un exemple de stockage côté serveur et de réutilisation de jeton, consultez Stockage des jetons.
Authorization de chaque requête subséquente à votre API. Ce jeton devrait être dans un format standard, comme les , puisque vous trouverez des bibliothèques pour la plupart des plateformes et que vous ne voudrez pas implémenter votre propre cryptographie.
Avec les deux approches, vous pouvez obtenir les mêmes informations de l’utilisateur. Cela est contrôlé par le paramètre scope envoyé dans la requête de connexion (soit avec Lock, notre bibliothèque JavaScript, soit avec un simple lien). Le scope est un paramètre de la méthode .signin({scope: 'openid name email'}), qui finit par faire partie de la chaîne de requête dans la requête de connexion.
Par défaut, nous utilisons scope=openid dans l’authentification basée sur les jetons afin d’éviter d’avoir un jeton trop volumineux. Vous pouvez contrôler toute claim standard de Connect (OIDC) que vous souhaitez obtenir dans le jeton en les ajoutant comme valeurs de scope. Par exemple, scope=openid name email family_name address phone_number. Pour en savoir plus, consultez Standard Claims on openid.net.
Vous pouvez combiner l’authentification basée sur les jetons avec l’authentification basée sur les témoins. Gardez à l’esprit que les témoins fonctionnent très bien si l’application Web et l’API sont hébergées sous le même domaine; vous n’aurez donc peut-être pas besoin d’une authentification basée sur les jetons. Au besoin, nous renvoyons aussi un JWT dans le flux de l’application Web. Chacun de nos SDK gère cela différemment. Si vous voulez appeler vos API à partir de JavaScript (au lieu d’utiliser le témoin existant), vous devez alors gérer les jetons d’accès à l’aide de Web Workers ou de closures JavaScript pour assurer la transmission et le stockage des jetons. Pour en savoir plus, consultez la section Browser in-memory scenarios de notre page Token Storage.
Utilisation des jetons d’actualisation
- Flux de code d’autorisation
- Flux de code d’autorisation avec clé de preuve pour l’échange de code (PKCE)
- Flux de mot de passe du propriétaire de la ressource
- Flux d’autorisation de l’appareil
offline_access dans votre requête).
Les Rules s’exécutent lors de l’échange du jeton d’actualisation. Pour exécuter une logique particulière, vous pouvez vérifier la propriété context.protocol dans votre Rule. Si la valeur est oauth2-refresh-token, cela signifie que la Rule s’exécute pendant l’échange.
Lorsque vous tentez d’obtenir un jeton d’actualisation, le paramètre n’est pas disponible dans l’objet de contexte des Rules. Si vous recevez une erreur lorsque vous tentez d’ajouter le paramètre audience, vérifiez qu’il n’est pas défini dans le jeton.
Si vous essayez d’effectuer une redirection avec context.redirect, le flux d’authentification renverra une erreur.
Si vous avez ajouté des claims personnalisées à vos jetons à l’aide d’une Rule, elles apparaîtront dans les nouveaux jetons émis lors de l’utilisation d’un jeton d’actualisation tant que votre Rule restera en place. Bien que les nouveaux jetons n’héritent pas automatiquement des claims personnalisées, les Rules s’exécutent pendant le flux du jeton d’actualisation, donc le même code sera exécuté. Cela vous permet d’ajouter ou de modifier des claims personnalisées dans les jetons nouvellement émis sans obliger les applications déjà autorisées à obtenir un nouveau jeton d’actualisation.
Limites des jetons d’actualisation
Tests automatisés
- Créez un utilisateur avec la Management API. Vous utiliserez cet utilisateur pour les tests.
- La réponse renvoie un
user_idque vous devez conserver pendant les tests pour pouvoir l’utiliser plus tard. - Une fois les tests terminés, supprimez l’utilisateur au moyen de la Management API. Lorsque l’utilisateur de test est supprimé, les artefacts associés le sont aussi, y compris les jetons d’actualisation.
- Répertoriez les jetons d’actualisation de l’utilisateur à l’aide du point de terminaison des identifiants d’appareil de la Management API. Le point de terminaison renverra un maximum de 1000 jetons, sans ordre particulier, peu importe le nombre de jetons accumulés ou l’utilisation de la pagination.
- Supprimez ces identifiants à l’aide de la méthode DELETE.
- Si l’utilisateur a plus de 1k jetons, répétez l’opération de listage et de suppression jusqu’à ce qu’il n’en reste plus pour cet utilisateur.
Configurer des jetons d’actualisation expirables
offline_access est demandé dans la demande d’autorisation, un nouveau jeton d’actualisation leur est émis. S’ils ferment ensuite leur session puis en ouvrent une nouvelle sur le même appareil, un nouveau jeton d’actualisation est émis. Selon la façon dont votre application stocke et utilise les jetons d’actualisation, l’ancien jeton d’actualisation de la première connexion peut devenir obsolète, et votre application utilisera très probablement les nouveaux jetons d’actualisation si les deux jetons sont émis avec la même audience. Pour en savoir plus, consultez Stockage des jetons.
Pour éviter l’accumulation de jetons d’actualisation obsolètes, même si la limite de jetons d’actualisation supprime d’abord le jeton le plus ancien, nous vous recommandons de configurer l’expiration des jetons d’actualisation. Les jetons d’actualisation avec rotation comme ceux sans rotation (ou réutilisables) peuvent être configurés pour expirer après une période d’inactivité ou après une durée absolue. Ces deux valeurs d’expiration aident à supprimer les jetons qui ne sont plus activement utilisés et à éviter leur accumulation pour l’utilisateur. Pour en savoir plus, consultez Configurer l’expiration des jetons d’actualisation.
Validation des JWT
Algorithmes de signature
- RS256 (signature RSA avec SHA-256) : un algorithme asymétrique, ce qui signifie qu’il y a deux clés : une clé publique et une clé privée qui doit rester secrète. Auth0 détient la clé privée utilisée pour générer la signature, et le destinataire du JWT récupère une clé publique à partir des points de terminaison de métadonnées fournis par Auth0 et l’utilise pour valider la signature du JWT.
- HS256 (HMAC avec SHA-256) : un algorithme symétrique, ce qui signifie qu’il n’y a qu’une seule clé privée qui doit rester secrète et qu’elle est partagée entre les deux parties. Comme la même clé est utilisée à la fois pour générer la signature et pour la valider, il faut veiller à ce qu’elle ne soit pas compromise. Cette clé privée (ou ce secret) est créée lorsque vous enregistrez votre application () ou votre API (secret de signature) et choisissez l’algorithme de signature HS256.
- Avec RS256, vous avez l’assurance que seul le détenteur de la clé privée (Auth0) peut signer des jetons, tandis que n’importe qui peut vérifier si le jeton est valide à l’aide de la clé publique.
- Avec RS256, vous pouvez demander un jeton valide pour plusieurs audiences.
- Avec RS256, si la clé privée est compromise, vous pouvez mettre en place une rotation des clés sans avoir à redéployer votre application ou votre API avec le nouveau secret (ce que vous devriez faire si vous utilisiez HS256).
- Avec HS256, si la clé secrète est compromise, vous devrez redéployer l’API avec le nouveau secret.