Introduction
La mise en œuvre de mécanismes d'authentification dans les serveurs Web est cruciale pour sécuriser les données des utilisateurs et contrôler l’accès aux ressources protégées. Lorsque vous utilisez le package httprouter pour le routage et Negroni pour la gestion des middlewares, vous devrez peut-être exclure des routes spécifiques de l'authentification. Cet article explore comment réaliser un middleware spécifique à la route dans Negroni.
Énoncé du problème
Étant donné une configuration de serveur avec httprouter et Negroni, l'objectif est d'implémenter un gestionnaire d'authentification (authenticator.Get()) et appliquez-le à toutes les routes sauf une (telle que "/login").
Solution
Pour le middleware spécifique à une route avec Negroni , nous devons créer des instances Negroni distinctes pour chaque route. Dans l'exemple fourni, des instances Negroni distinctes sont créées pour "/login" et "/". La route "/login" est exclue de l'authentification en utilisant uniquement le loginHandler, tandis que la route "/" utilise à la fois Authenticator.Get() et indexHandler.
Implémentation
<code class="go">router := httprouter.New() router.Handler("GET", "/login", negroni.New(negroni.HandlerFunc(loginHandler))) router.Handler("GET", "/", negroni.New(authenticator.Get(), negroni.HandlerFunc(indexHandler))) server := negroni.Classic() server.UseHandler(router) server.Use(sessions.Sessions("example-web-dev", cookiestore.New([]byte("some secret")))) server.Run(":3000")</code>
Points clés
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!