Maison > développement back-end > tutoriel php > Utilisation avancée et exemple de démonstration du middleware du framework Symfony

Utilisation avancée et exemple de démonstration du middleware du framework Symfony

WBOY
Libérer: 2023-07-29 07:06:01
original
1393 Les gens l'ont consulté

Utilisation avancée et exemple de démonstration du middleware du framework Symfony

Introduction :
Le middleware est l'un des concepts courants dans les frameworks Web modernes. Il peut effectuer un traitement multicouche des requêtes et des réponses HTTP, prétraiter la requête ou effectuer un traitement sur la réponse. Post-traitement. Le framework Symfony fournit également de riches fonctions middleware. Cet article présentera l'utilisation avancée du middleware du framework Symfony et démontrera ses fonctions à travers des exemples pratiques.

  1. Utilisation du middleware dans Symfony
    Le middleware Symfony est implémenté via Kernel et EventSubscriber. Avant d'utiliser le middleware, nous devons nous assurer que le framework Symfony a été installé et qu'un projet a été créé.

1.1 Créer un middleware personnalisé
Nous pouvons définir notre propre middleware en créant une nouvelle classe. Tout d’abord, créez un nouveau fichier SampleMiddleware.php dans le répertoire src/Middleware.

<?php

namespace AppMiddleware;

use SymfonyComponentHttpFoundationRequest;
use SymfonyComponentHttpFoundationResponse;

class SampleMiddleware
{
    public function handle(Request $request, Closure $next)
    {
        // 在中间件处理请求之前的逻辑
        // ...

        // 调用下一个中间件或路由处理器
        $response = $next($request);

        // 在中间件处理完响应之后的逻辑
        // ...

        return $response;
    }
}
Copier après la connexion

Dans l'exemple ci-dessus, nous avons défini une classe SampleMiddleware et implémenté la méthode handle, qui reçoit l'objet de requête $request et une fermeture $next comme paramètres. Dans cette méthode, nous pouvons écrire la logique avant que le middleware ne traite la requête et la logique après avoir traité la réponse.

1.2 Enregistrer le middleware
Ensuite, nous devons enregistrer le middleware personnalisé dans le framework Symfony. Ouvrez le fichier config/services.yaml et ajoutez la configuration suivante :

services:  
    AppMiddlewareSampleMiddleware:
        tags:
            - { name: kernel.event_subscriber }
Copier après la connexion

Grâce à la configuration ci-dessus, le framework découvrira et enregistrera automatiquement le middleware que nous avons défini.

  1. Utilisation avancée du middleware
    Le framework Symfony fournit de riches fonctions middleware, notamment un middleware de routage, un middleware global et un middleware de gestion des exceptions, etc. Ce qui suit présentera comment utiliser respectivement ces trois middlewares.

2.1 Middleware de routage
Le middleware de routage peut traiter des chemins spécifiques. Nous pouvons spécifier les routes auxquelles le middleware doit être appliqué dans le fichier routes.yaml.

index:
    path: /
    controller: AppControllerDefaultController::indexAction
    middleware: ['AppMiddlewareSampleMiddleware']
Copier après la connexion

Dans l'exemple ci-dessus, nous avons appliqué le middleware SampleMiddleware à la demande de routage du chemin d'index.

2.2 Middleware global
Le middleware global peut être appliqué à toutes les routes et est très utile pour la logique qui doit être traitée pour chaque requête. Nous pouvons configurer un middleware global dans le fichier config/packages/framework.yaml.

framework:
    middleware: ['AppMiddlewareSampleMiddleware']
Copier après la connexion

Avec la configuration ci-dessus, le middleware SampleMiddleware sera appliqué à toutes les requêtes de routage.

2.3 Middleware de gestion des exceptions
Le middleware de gestion des exceptions peut être utilisé pour gérer les exceptions lancées dans les applications. Nous pouvons créer un nouveau middleware pour détecter les exceptions et les gérer.

<?php

namespace AppMiddleware;

use SymfonyComponentHttpFoundationRequest;
use SymfonyComponentHttpFoundationResponse;
use SymfonyComponentHttpKernelExceptionHttpExceptionInterface;

class ExceptionHandlerMiddleware
{
    public function handle(Request $request, Closure $next)
    {
        try {
            $response = $next($request);
        } catch (HttpExceptionInterface $e) {
            $response = new Response($e->getMessage(), $e->getStatusCode());
        }

        return $response;
    }
}
Copier après la connexion

Dans l'exemple ci-dessus, nous avons créé une classe ExceptionHandlerMiddleware et utilisé un bloc try-catch dans la méthode handle pour intercepter l'exception HttpExceptionInterface levée. Si une exception est interceptée, nous pouvons personnaliser la gestion selon nos besoins.

  1. Exemple de démonstration
    Ensuite, nous utiliserons un exemple pour démontrer l'application du middleware dans le framework Symfony.

Supposons que nous ayons une exigence. Lorsqu'un utilisateur accède au chemin /admin, nous devons vérifier s'il est connecté. Si vous n'êtes pas connecté, accédez à la page de connexion. Si vous êtes connecté, continuez à visiter la page d'administration. Nous pouvons répondre à cette exigence en créant un middleware.

Tout d’abord, créez un middleware AdminMiddleware.

<?php

namespace AppMiddleware;

use SymfonyComponentHttpFoundationRequest;
use SymfonyComponentHttpFoundationResponse;
use SymfonyComponentHttpKernelExceptionAccessDeniedHttpException;

class AdminMiddleware
{
    public function handle(Request $request, Closure $next)
    {
        // 检查用户是否已登录
        // ...

        // 如果未登录,则抛出AccessDeniedHttpException异常
        if (!$user->isLoggedIn()) {
            throw new AccessDeniedHttpException('Access Denied');
        }

        return $next($request);
    }
}
Copier après la connexion

Ensuite, appliquez le middleware AdminMiddleware à la route du chemin /admin.

admin:
    path: /admin
    controller: AppControllerAdminController::indexAction
    middleware: ['AppMiddlewareAdminMiddleware']
Copier après la connexion

Avec la configuration ci-dessus, lorsque l'utilisateur accède au chemin /admin, le middleware AdminMiddleware vérifiera si l'utilisateur est connecté. S'il n'est pas connecté, l'utilisateur sera redirigé vers la page de connexion ; s'il est connecté, continuez vers la page d'administration.

Conclusion :
Cet article présente l'utilisation avancée et un exemple de démonstration du middleware du framework Symfony. En personnalisant le middleware et en configurant le middleware, nous pouvons traiter de manière flexible les demandes et les réponses pour répondre à diverses exigences fonctionnelles. Cela nous permet de développer des applications Web efficaces et évolutives.

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!

Étiquettes associées:
source:php.cn
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal