Utiliser l’IA pour intégrer Auth0
Utiliser l’IA pour intégrer Auth0
Si vous utilisez un assistant de programmation IA comme Claude Code, Cursor ou GitHub Copilot, vous pouvez ajouter automatiquement l’authentification de votre API avec Auth0 en quelques minutes grâce aux agent skills.Installation :Ensuite, demandez à votre assistant IA :Votre assistant IA créera automatiquement votre API Auth0, récupérera les identifiants, installera
express-oauth2-jwt-bearer, configurera le middleware JWT et protégera les points de terminaison de votre API avec la validation des jetons. Documentation complète sur les agent skills →Prérequis : Avant de commencer, assurez-vous d’avoir installé les éléments suivants :
- Node.js 18 LTS ou une version plus récente (prend en charge
^18.12.0 || ^20.2.0 || ^22.1.0 || ^24.0.0) - npm 8+ ou yarn 1.22+ ou pnpm 8+
node --version && npm --versionCompatibilité des versions d’Express : Ce guide de démarrage rapide fonctionne avec Express 4.x et Express 5.x.Pour commencer
Créer un nouveau projet
Créez un nouveau répertoire pour votre API Express et initialisez un projet Node.js.Initialisez le projetCréer la structure du projet
Installez le SDK express-oauth2-jwt-bearer
Installez les dépendances requisesAjoutez des scripts de démarrage à votre
package.json :package.json
Configurez votre API Auth0
Ensuite, vous devez créer une nouvelle API dans votre locataire Auth0 et ajouter les variables d’environnement à votre projet.Vous avez deux options pour configurer votre API Auth0 : utiliser une commande CLI ou passer par Auth0 Dashboard :
- CLI
- Dashboard
Exécutez la commande suivante à la racine de votre projet pour créer une API Auth0 :Après la création, copiez les valeurs Identifier et Domain, puis créez votre fichier
Cette commande permet de :
- Vérifier si vous êtes authentifié (et vous demander de vous connecter au besoin)
- Créer une API Auth0 avec l’identifiant spécifié
- Afficher les détails de l’API, y compris le domaine et l’identifiant
.env :.env
Remplacez
YOUR_AUTH0_DOMAIN par le domaine de votre locataire Auth0 (par exemple, dev-abc123.us.auth0.com) et YOUR_API_IDENTIFIER par l’identifiant de votre API (par exemple, https://my-express-api.example.com).Configurer le middleware JWT
Créez votre serveur Express et configurez la validation du JWT :Ce que cela fait :
server.js
- Crée un intergiciel de validation JWT à l’aide de votre Domaine Auth0 et de l’audience de l’API
- Valide les claims
issetauddes jetons d’accès entrants - Met
checkJwtà votre disposition pour protéger des routes individuelles
Créer des routes API
Ajoutez des routes publiques et protégées dans votre Points clés :
server.js :server.js
- Les routes publiques ne nécessitent pas d’authentification
- Les routes protégées utilisent le middleware
checkJwtpour exiger un JWT valide - Les routes avec scopes utilisent
requiredScopes()pour exiger des autorisations précises dans le JWT req.auth.payloadcontient les claims décodées du JWT pour les requêtes authentifiées- La claim
subcontient l’identifiant unique de l’utilisateur
Démarrez votre API
Démarrez le serveur de développement :Votre API s’exécute maintenant à l’adresse http://localhost:3001.
L’option
--watch de Node.js 18+ redémarre automatiquement le serveur lorsque les fichiers sont modifiés.Testez votre API
Testez le point de terminaison public (aucune authentification n’est requise) :Vous devriez voir :Testez le point de terminaison protégé sans jeton (devrait échouer) :Vous devriez voir une erreur 401 Non autorisé :Pour effectuer un test avec un jeton valide :Vous devriez voir :
- Accédez à Auth0 Dashboard → Applications → APIs
- Sélectionnez votre API → onglet Test
- Copiez le jeton d’accès généré
Point de contrôleVous devriez maintenant avoir une API protégée. Votre API :
- Accepte les requêtes vers des points de terminaison publics sans authentification
- Rejette les requêtes vers des points de terminaison protégés sans jeton valide
- Valide les jetons JWT par rapport à votre domaine Auth0 et à l’audience
- Fournit des informations sur l’utilisateur à partir des claims du jeton via
req.auth.payload
Utilisation avancée
Autorisation basée sur les scopes
Autorisation basée sur les scopes
Les scopes permettent un contrôle d’accès précis. Vous pouvez exiger des scopes spécifiques pour différents points de terminaison.Configurer les scopes dans Auth0 :
- Dans le Auth0 Dashboard, accédez à Applications → APIs → Votre API
- Accédez à l’onglet Permissions
- Ajoutez des permissions comme
read:messages,write:messages,admin:access
server.js
Si une requête ne contient pas le scope requis, l’API renvoie
403 Forbidden avec une erreur insufficient_scope. Assurez-vous que l’application cliente demande les scopes appropriés lorsqu’elle obtient un jeton d’accès.Validation des claims personnalisées
Validation des claims personnalisées
En plus des scopes, vous pouvez valider des claims personnalisées dans le payload JWT :
server.js
Les claims personnalisées doivent utiliser des URL dans un espace de noms (par exemple,
https://myapp.com/roles), sauf s’il s’agit de claims OIDC standard. En savoir plus sur les claims personnalisées.Authentification facultative (routes publiques/privées mixtes)
Authentification facultative (routes publiques/privées mixtes)
Autorisez à la fois l’accès authentifié et l’accès anonyme à une même route :
server.js
Configuration CORS
Configuration CORS
Activez CORS pour autoriser les requêtes provenant d’applications Web :En production, précisez les origines exactes :
server.js
server.js
Gestion personnalisée des erreurs
Gestion personnalisée des erreurs
Ajoutez une gestion complète des erreurs d’authentification :
server.js
Prise en charge de TypeScript
Prise en charge de TypeScript
Pour les projets TypeScript, installez les définitions de type et configurez votre projet :Créez Ajoutez un Exécutez la commande suivante :
server.ts :server.ts
tsconfig.json :tsconfig.json
npx ts-node server.tsDépannage
Problèmes courants et solutions
Problèmes courants et solutions
« Aucun jeton d’autorisation n’a été trouvé »
Problème : L’API ne trouve pas le jeton d’accès dans la requête.Solutions :- Assurez-vous que l’en-tête
Authorizationest présent :Authorization: Bearer YOUR_TOKEN - Vérifiez que « Bearer » figure bien avant le jeton
- Vérifiez que le jeton n’est pas expiré
« Jeton invalide » ou « jwt malformed »
Problème : Le format du jeton est invalide.Solutions :- Assurez-vous d’utiliser un jeton d’accès, et non un jeton d’identité
- Le jeton doit être obtenu avec le paramètre
audiencede votre API - Vérifiez que le jeton est un JWT valide (il doit comporter trois parties séparées par des points)
Valeur « iss » ou « aud » inattendue
Problème : L’émetteur ou l’audience du jeton ne correspondent pas à votre configuration.Solutions :- Décodez votre jeton sur jwt.io
- Vérifiez que la claim
isscorrespond àhttps://YOUR_AUTH0_DOMAIN/(notez la barre oblique à la fin) - Vérifiez que la claim
audcorrespond exactement à votreAUTH0_AUDIENCE - Vérifiez les valeurs de votre
.env:
« You must provide an issuerBaseURL » ou « audience is required »
Problème : Les variables d’environnement ne sont pas chargées.Solutions :- Assurez-vous que le fichier
.envexiste à la racine de votre projet - Vérifiez que
dotenvest installé :npm install dotenv - Ajoutez
require('dotenv').config()tout en haut de votre fichier serveur - Vérifiez que les noms des variables correspondent exactement (respect de la casse)
401 Non autorisé sur toutes les requêtes
Causes possibles :- Le jeton est expiré
- L’audience ne correspond pas
- L’émetteur ne correspond pas
- Décodez votre jeton sur jwt.io
- Vérifiez que la claim
expn’est pas échue - Vérifiez que la claim
audcorrespond exactement à votreAUTH0_AUDIENCE - Vérifiez que la claim
issesthttps://{AUTH0_DOMAIN}/ - Assurez-vous que l’en-tête Authorization est au format
Bearer YOUR_TOKEN(avec un espace)
403 Interdit avec « insufficient_scope »
Problème : Le jeton n’a pas les scopes requis.Solutions :- Vérifiez que les scopes sont définis dans votre API Auth0 (Auth0 Dashboard → Applications → APIs → Permissions)
- Demandez les scopes lors de l’obtention du jeton
- Vérifiez que la claim
scopedu jeton inclut les scopes requis
Erreurs CORS dans le navigateur
Problème : Le navigateur bloque les requêtes API en raison de la stratégie CORS.Solution : Installez et configurezcors :Prochaines étapes
- Contrôle d’accès basé sur les rôles - Implémentez des autorisations granulaires
- Meilleures pratiques pour l’autorisation des API - Découvrez les meilleures pratiques relatives aux jetons d’accès
- Surveiller votre API - Configurez la journalisation et la surveillance
- Communauté Auth0 - Obtenez de l’aide auprès de la communauté
Ressources
- express-oauth2-jwt-bearer GitHub - Code source et exemples
- Documentation d’Express.js - En savoir plus sur Express
- Authentification de l’API Auth0 - Comprendre les jetons d’accès
- JWT.io - Déboguer et décoder les JWT