laravel jwt supprimer
Avant-propos
Dans le processus d'utilisation de Laravel et JWT pour le développement Web, vous pouvez rencontrer la situation de suppression de JWT. Cet article explique comment supprimer JWT dans le framework Laravel.
La nécessité de supprimer JWT
JWT résout bien les problèmes d'authentification et d'autorisation des utilisateurs, mais dans certains cas, vous devrez peut-être supprimer JWT. Voici quelques raisons pour lesquelles :
- Problèmes de sécurité : les JWT compromis ou compromis peuvent entraîner de graves vulnérabilités de sécurité.
- Problèmes d'abus : si votre application collecte des données sur l'activité de l'utilisateur, vous devrez peut-être supprimer le JWT pour arrêter de collecter des données lorsque l'utilisateur se déconnecte ou quitte l'application.
- Pour le débogage : la suppression du JWT peut vous aider à resimuler le flux de connexion de l'utilisateur.
Étapes pour supprimer un JWT
Pour supprimer un JWT, il y a trois étapes :
- Révoquer un JWT : Un JWT peut être révoqué, le rendant invalide. Pour y parvenir, vous devez conserver une liste noire des JWT stockés.
- Modifier la période de validité du JWT : vous pouvez définir la période de validité du JWT sur une durée plus courte pour garantir que les JWT potentiellement volés expirent plus rapidement.
- Supprimer les JWT : vous pouvez demander aux utilisateurs de supprimer les JWT manuellement ou de les supprimer en écrivant du code.
Nous expliquerons ces étapes plus en détail.
Révoquer JWT
La révocation de JWT vous oblige à maintenir une liste noire JWT. Lorsqu'un utilisateur se déconnecte ou quitte l'application, ajoutez le JWT de l'utilisateur à la liste noire. Lorsqu'un utilisateur tente d'accéder à votre application à l'aide de ce JWT, votre application vérifie si le JWT figure sur la liste noire. Si tel est le cas, l’utilisateur n’est pas autorisé à accéder à votre candidature. Voici les étapes pour y parvenir :
Étape 1 : Créer un middleware
Créez un middleware appelé "JwtBlacklist".
php artisan make:middleware JwtBlacklist
Étape 2 : Écrivez le code
Écrivez le code suivant dans la méthode handle du middleware :
public function handle($request, Closure $next) { $token = $request->bearerToken(); if(auth()->check()){ auth()->logout(); JWTAuth::invalidate(JWTAuth::getToken()); return response()->json(['message' => 'Logout successful']); }elseif($token){ try { JWTAuth::parseToken()->authenticate(); JWTAuth::invalidate(JWTAuth::getToken()); return response()->json(['message' => 'Logout successful']); } catch (JWTException $e) { // ignore errors } } return $next($request); }
Étape 3 : Enregistrez le middleware
Enregistrez le middleware dans le tableau $routeMiddleware de l'application/Http/Kernel. fichier php.
'jwt.blacklist' => AppHttpMiddlewareJwtBlacklist::class,
Modifier la période de validité de JWT
JWT se compose de trois parties, à savoir l'en-tête (objet JSON codé en Base64), la charge utile (objet JSON codé en Base64) et la signature. Par conséquent, vous pouvez modifier la période de validité dans le chargement.
Dans Laravel/JWT, vous pouvez utiliser le code suivant :
public function login(Request $request) { $credentials = $request->only('email', 'password'); if ($token = JWTAuth::attempt($credentials, ['exp' => Carbon::now()->addHours(24)->timestamp])) { return response()->json(['message' => 'Success', 'token' => $token]); } return response()->json(['error' => 'Unauthorized'], 401); }
Dans le code ci-dessus, nous fixons la période de validité du JWT à 24 heures.
Supprimer JWT
Si vous demandez aux utilisateurs de supprimer manuellement un JWT, vous devez indiquer clairement ces informations à l'utilisateur. Vous pouvez fournir un bouton ou un lien pour l'action de déconnexion afin que l'utilisateur puisse supprimer le JWT.
Si vous souhaitez supprimer le JWT en écrivant du code, vous pouvez ajouter le code suivant à votre contrôleur :
public function logout(Request $request) { JWTAuth::invalidate(JWTAuth::getToken()); return response()->json(['message' => 'Logout successful']); }
Ce contrôleur supprimera le JWT lorsque l'utilisateur clique sur le bouton de déconnexion.
Conclusion
Cet article explique comment supprimer JWT dans Laravel et JWT. Vous pouvez le faire en révoquant, en modifiant la période de validité du JWT et en supprimant le JWT. Si vous avez des questions ou des requêtes, veuillez laisser un message dans la zone de commentaire et je vous répondrai dans les plus brefs délais.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Cet article détaille la mise en œuvre d'authentification et d'autorisation OAuth 2.0 dans Laravel. Il couvre à l'aide de packages comme les solutions de ligue / oauth2-serveur ou spécifiques au fournisseur, mettant l'accent sur la configuration de la base de données, l'enregistrement du client, la configuration du serveur d'autorisation

L'article discute de la création et de la personnalisation des éléments d'interface utilisateur réutilisables dans Laravel à l'aide de composants, offrant les meilleures pratiques pour l'organisation et suggérant des packages améliorant.

L'article traite des meilleures pratiques pour déployer Laravel dans des environnements natifs du cloud, en se concentrant sur l'évolutivité, la fiabilité et la sécurité. Les problèmes clés incluent la conteneurisation, les microservices, la conception sans état et les stratégies d'optimisation.

L'article discute de la création et de l'utilisation des directives de lame personnalisées à Laravel pour améliorer les modèles. Il couvre la définition des directives, les utilisant dans des modèles et les gérer dans de grands projets, mettant en évidence des avantages tels que l'amélioration de la réutilisabilité du code et R

L'article discute de la création et de l'utilisation de règles de validation personnalisées dans Laravel, offrant des étapes pour les définir et les mettre en œuvre. Il met en évidence des avantages tels que la réutilisabilité et la spécificité et fournit des méthodes pour étendre le système de validation de Laravel.

Cet article explore des stratégies optimales de téléchargement de fichiers et de stockage cloud dans Laravel. Il examine le stockage local vs fournisseurs de cloud (AWS S3, Google Cloud, Azure, DigitalOcean), mettant l'accent sur la sécurité (validation, désinfection, HTTPS) et Performance Opti

La console artisanale de Laravel automatise des tâches comme la génération de code, l'exécution de migrations et la planification. Les commandes clés incluent la marque: contrôleur, migrer et db: graines. Les commandes personnalisées peuvent être créées pour des besoins spécifiques, améliorant l'efficacité du flux de travail.

L'article discute de l'utilisation du routage de Laravel pour créer des URL conviviales, couvrant les meilleures pratiques, des URL canoniques et des outils pour l'optimisation du référencement. Nombre de mots: 159
