image
image
image
image
image
image

Aws jwt verify

JSON Web Tokens (JWT) pour l’authentification et l’autorisation dans AWS

Les JSON Web Tokens (JWT) sont un type compact de jeton d’accès utilisé pour transmettre en toute sécurité des informations entre les parties. Dans le contexte de l’authentification, un JWT peut être utilisé comme un moyen sécurisé et sans état d’authentifier les utilisateurs et d’autoriser l’accès aux ressources. Il peut être vérifié localement par le client sans qu’il soit nécessaire d’appeler le service tiers (tel qu’un fournisseur OAuth) chaque fois que le client souhaite accéder à une ressource protégée.

Les JWT peuvent être vérifiés localement car ils sont autonomes et contiennent toutes les informations nécessaires pour vérifier leur authenticité. Un JWT se compose de trois parties : un en-tête, une charge utile et une signature.

  • L’en-tête contient des informations sur le type de jeton et l’algorithme utilisé pour le signer.
  • La charge utile contient les revendications ou les assertions sur l’utilisateur ou l’entité que le jeton représente.
  • La signature est créée en combinant l’en-tête, la charge utile et une clé secrète qui n’est connue que du serveur. La signature peut être utilisée pour vérifier l’authenticité du JWT.

Lorsqu’un client envoie un JWT à un serveur, celui-ci peut vérifier l’authenticité du jeton en décodant le jeton, en vérifiant la signature à l’aide de la clé secrète et en vérifiant que les revendications de la charge utile sont valides. Étant donné que la clé secrète n’est connue que du serveur, ce processus garantit que seuls les jetons émis par le serveur sont acceptés et que les revendications du jeton n’ont pas été falsifiées.

Contrairement à OAuth, qui s’appuie sur un serveur d’autorisation centralisé pour gérer les jetons d’accès, les JWT peuvent être vérifiés localement sans qu’il soit nécessaire de disposer d’un Service tiers . Cela fait des JWT une bonne option pour les applications qui ont besoin d’authentifier et d’autoriser les utilisateurs sans dépendre de services externes.

Voici comment vous pouvez utiliser les JWT pour l’authentification et l’autorisation :

  1. Le client (par exemple, une application Web ou mobile) envoie une requête à votre serveur avec un nom d’utilisateur et un mot de passe.
  2. - Votre serveur authentifie l’utilisateur et génère un JWT qui inclut l’ID de l’utilisateur et toutes les autorisations ou rôles pertinents.
  3. - Votre serveur renvoie le JWT au client dans la réponse.
  4. - .
  5. - Votre serveur vérifie le JWT en vérifiant la signature et en décodant les revendications (telles que l’ID utilisateur et les autorisations).
  6. - Si le JWT est valide, votre serveur autorise la requête et Renvoie la ressource demandée ou effectue l’action demandée.
  7. - Si le JWT n’est pas valide ou a expiré, votre serveur renvoie une réponse d’erreur. _

Pour utiliser JWT (JSON Web Token) dans AWS à l’aide de Python, vous pouvez suivre les étapes suivantes :

1.Créez un jeton JWT à l’aide de PyJWT :

Dans cet exemple, la charge utile est un dictionnaire qui inclut l’ID utilisateur et les autorisations. La clé secrète est une chaîne de caractères utilisée pour signer le JWT. La fonction jwt.encode() encode la charge utile et la signe avec la clé secrète à l’aide de l’algorithme HS256.

2.- Vérifier le JWT dans API Gateway :
Effectuez une requête API à un service AWS (par exemple, AWS Lambda) et incluez le jeton JWT dans les en-têtes de requête :

Dans l’exemple ci-dessus, nous effectuons une requête HTTP GET à une fonction AWS Lambda à l’aide de la bibliothèque de requêtes. Nous incluons le jeton JWT dans les en-têtes de demande à l’aide du champ Authorization avec le préfixe Bearer.

Notez que la variable token doit être décodée en une chaîne avant de pouvoir être incluse dans les en-têtes.

Voilà! Vous devriez maintenant être en mesure d’utiliser JWT dans AWS à l’aide de Python.