Maison cadre php Laravel Comment utiliser le middleware pour l'authentification API dans Laravel

Comment utiliser le middleware pour l'authentification API dans Laravel

Nov 02, 2023 am 08:43 AM
laravel 中间件 api认证

Comment utiliser le middleware pour lauthentification API dans Laravel

Comment utiliser le middleware pour l'authentification API dans Laravel

Le middleware (Middleware) joue un rôle très important dans le framework Laravel. Il peut être utilisé pour exécuter une logique de code avant et après que la requête HTTP atteigne l'application. Lors du développement d'applications API, nous devons généralement authentifier les utilisateurs pour garantir que seuls les utilisateurs légitimes peuvent accéder aux données sensibles ou utiliser l'API.

Cet article expliquera comment utiliser le middleware pour l'authentification API. L'exemple spécifique est basé sur le framework Laravel. Nous mettrons en œuvre un schéma d'authentification de base par jeton pour protéger notre interface API.

Tout d'abord, nous devons créer un middleware pour vérifier le jeton. Exécutez la commande suivante pour créer un middleware nommé « ApiAuthMiddleware » :

php artisan make:middleware ApiAuthMiddleware
Copier après la connexion

Après une opération réussie, vous verrez le fichier middleware généré dans le répertoire app/Http/Middleware.

Ensuite, implémentez la méthode Authenticate() dans ApiAuthMiddleware, qui vérifiera si le Token dans la requête est valide :

<?php

namespace AppHttpMiddleware;

use Closure;
use IlluminateHttpRequest;

class ApiAuthMiddleware
{
    public function handle(Request $request, Closure $next)
    {
        $token = $request->header('Authorization');

        if (!$token) {
            return response()->json(['message' => 'Token not provided'], 401);
        }

        // 这里可根据具体业务逻辑来验证Token的有效性,比如查询数据库或使用第三方服务进行验证

        if ($token !== 'valid_token') {
            return response()->json(['message' => 'Invalid Token'], 401);
        }

        // Token验证通过,继续执行请求
        return $next($request);
    }
}
Copier après la connexion

Dans le code ci-dessus, nous obtenons d'abord le Token de l'en-tête de la requête, puis en fonction de l'entreprise spécifique logique Vérifier la validité du Token. Si le jeton n'existe pas ou si la validation échoue, une erreur 401 non autorisée est renvoyée ; sinon, nous transmettons la demande au prochain middleware ou gestionnaire de route.

Ensuite, nous devons enregistrer ApiAuthMiddleware en tant que middleware global afin que l'authentification par jeton se produise dans chaque requête API. Ajoutez le code suivant dans le tableau $routeMiddleware du fichier app/Http/Kernel.php :

protected $routeMiddleware = [
    // ...
    'api.auth' => AppHttpMiddlewareApiAuthMiddleware::class,
];
Copier après la connexion

Dans le code ci-dessus, nous enregistrons ApiAuthMiddleware comme alias middleware 'api.auth'.

Nous pouvons désormais utiliser le middleware 'api.auth' dans les routes ou les méthodes de contrôleur qui nécessitent une authentification API. Voici un exemple :

<?php

namespace AppHttpControllers;

use IlluminateHttpRequest;

class ApiController extends Controller
{
    public function __construct()
    {
        $this->middleware('api.auth');
    }

    public function getData(Request $request)
    {
        return response()->json(['message' => 'Authorized'], 200);
    }
}
Copier après la connexion

Dans le code ci-dessus, nous utilisons la méthode middleware() dans le constructeur d'ApiController pour appliquer le middleware 'api.auth' à toutes les méthodes de ce contrôleur. Dans la méthode getData(), nous renvoyons un simple message de réussite d’autorisation.

Désormais, lorsque nous lancerons une requête GET vers "/api/data", la requête sera d'abord authentifiée par ApiAuthMiddleware. Si le jeton dans la demande est valide, un message d'autorisation réussie sera renvoyé ; sinon, une erreur 401 non autorisée sera renvoyée.

Résumé

En utilisant un middleware pour l'authentification API, nous pouvons facilement protéger notre interface API et autoriser uniquement les utilisateurs légitimes à y accéder. Dans cet article, nous avons appris comment créer et utiliser un middleware personnalisé pour vérifier la validité d'un jeton et l'enregistrer en tant que middleware global.

Bien sûr, ce n'est qu'un exemple basique, vous pouvez étendre et personnaliser la logique d'authentification en fonction des besoins de votre entreprise. Parallèlement, vous pouvez également utiliser d'autres types de méthodes d'authentification, telles que OAuth, JWT, etc. Les puissantes capacités middleware du framework Laravel fournissent une solution flexible et facilement extensible pour l'authentification API.

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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Comparaison des dernières versions de Laravel et CodeIgniter Comparaison des dernières versions de Laravel et CodeIgniter Jun 05, 2024 pm 05:29 PM

Les dernières versions de Laravel 9 et CodeIgniter 4 fournissent des fonctionnalités et des améliorations mises à jour. Laravel9 adopte l'architecture MVC et fournit des fonctions telles que la migration de bases de données, l'authentification et le moteur de modèles. CodeIgniter4 utilise l'architecture HMVC pour fournir le routage, l'ORM et la mise en cache. En termes de performances, le modèle de conception basé sur le fournisseur de services de Laravel9 et le framework léger de CodeIgniter4 lui confèrent d'excellentes performances. Dans les applications pratiques, Laravel9 convient aux projets complexes qui nécessitent de la flexibilité et des fonctions puissantes, tandis que CodeIgniter4 convient au développement rapide et aux petites applications.

Laravel - Commandes artisanales Laravel - Commandes artisanales Aug 27, 2024 am 10:51 AM

Laravel - Artisan Commands - Laravel 5.7 est livré avec une nouvelle façon de traiter et de tester de nouvelles commandes. Il inclut une nouvelle fonctionnalité de test des commandes artisanales et la démonstration est mentionnée ci-dessous ?

Comment les capacités de traitement des données de Laravel et de CodeIgniter se comparent-elles ? Comment les capacités de traitement des données de Laravel et de CodeIgniter se comparent-elles ? Jun 01, 2024 pm 01:34 PM

Comparez les capacités de traitement des données de Laravel et CodeIgniter : ORM : Laravel utilise EloquentORM, qui fournit un mappage relationnel classe-objet, tandis que CodeIgniter utilise ActiveRecord pour représenter le modèle de base de données en tant que sous-classe de classes PHP. Générateur de requêtes : Laravel dispose d'une API de requêtes chaînées flexible, tandis que le générateur de requêtes de CodeIgniter est plus simple et basé sur des tableaux. Validation des données : Laravel fournit une classe Validator qui prend en charge les règles de validation personnalisées, tandis que CodeIgniter a moins de fonctions de validation intégrées et nécessite un codage manuel des règles personnalisées. Cas pratique : l'exemple d'enregistrement d'utilisateur montre Lar

Lequel est le plus adapté aux débutants, Laravel ou CodeIgniter ? Lequel est le plus adapté aux débutants, Laravel ou CodeIgniter ? Jun 05, 2024 pm 07:50 PM

Pour les débutants, CodeIgniter a une courbe d'apprentissage plus douce et moins de fonctionnalités, mais couvre les besoins de base. Laravel offre un ensemble de fonctionnalités plus large mais a une courbe d'apprentissage légèrement plus raide. En termes de performances, Laravel et CodeIgniter fonctionnent bien. Laravel dispose d'une documentation plus complète et d'un support communautaire actif, tandis que CodeIgniter est plus simple, léger et possède de solides fonctionnalités de sécurité. Dans le cas pratique de la création d'une application de blog, EloquentORM de Laravel simplifie la manipulation des données, tandis que CodeIgniter nécessite une configuration plus manuelle.

Laravel vs CodeIgniter : quel framework est le meilleur pour les grands projets ? Laravel vs CodeIgniter : quel framework est le meilleur pour les grands projets ? Jun 04, 2024 am 09:09 AM

Lors du choix d'un framework pour de grands projets, Laravel et CodeIgniter ont chacun leurs propres avantages. Laravel est conçu pour les applications d'entreprise, offrant une conception modulaire, une injection de dépendances et un ensemble de fonctionnalités puissantes. CodeIgniter est un framework léger plus adapté aux projets de petite et moyenne taille, mettant l'accent sur la rapidité et la facilité d'utilisation. Pour les grands projets avec des exigences complexes et un grand nombre d'utilisateurs, la puissance et l'évolutivité de Laravel sont plus adaptées. Pour les projets simples ou les situations avec des ressources limitées, les capacités de développement légères et rapides de CodeIgniter sont plus idéales.

Laravel vs CodeIgniter : quel framework est le meilleur pour les petits projets ? Laravel vs CodeIgniter : quel framework est le meilleur pour les petits projets ? Jun 04, 2024 pm 05:29 PM

Pour les petits projets, Laravel convient aux projets plus importants qui nécessitent des fonctionnalités et une sécurité élevées. CodeIgniter convient aux très petits projets qui nécessitent légèreté et facilité d'utilisation.

Quel est le meilleur moteur de template, Laravel ou CodeIgniter ? Quel est le meilleur moteur de template, Laravel ou CodeIgniter ? Jun 03, 2024 am 11:30 AM

En comparant le moteur de modèles Blade de Laravel et le moteur de modèles Twig de CodeIgniter, choisissez en fonction des besoins du projet et de vos préférences personnelles : Blade est basé sur la syntaxe MVC, qui encourage une bonne organisation du code et un héritage de modèles. Twig est une bibliothèque tierce qui offre une syntaxe flexible, des filtres puissants, une prise en charge étendue et un bac à sable de sécurité.

Gestion de la réutilisation des middlewares et du partage des ressources dans le framework Java Gestion de la réutilisation des middlewares et du partage des ressources dans le framework Java Jun 01, 2024 pm 03:10 PM

Le framework Java prend en charge la réutilisation des middlewares et le partage des ressources, y compris les stratégies suivantes : Gestion des connexions middleware préétablies via des pools de connexions. Tirez parti du stockage local des threads pour associer les connexions middleware au thread actuel. Utilisez un pool de threads pour gérer les threads réutilisables. Stockez des copies des données fréquemment consultées via des caches locaux ou distribués.

See all articles