recherche
Maisondéveloppement back-endtutoriel phpAuthentification plus facile avec la garde dans Symfony 3

Composant de garde de Symfony: rationalisation de l'authentification personnalisée

Symfony 2.8 et 3 ont introduit le composant Guard, simplifiant considérablement la création d'authentification personnalisée. Intégrant parfaitement le système de sécurité de Symfony, Guard propose une interface unifiée gérant l'intégralité de la chaîne d'authentification. Cela permet une personnalisation approfondie du processus d'authentification, englobant la soumission de formulaire, la vérification des informations d'identification et la gestion des tentatives d'authentification réussies et ratées. Son adaptabilité s'étend à divers types d'authentification, y compris la forme, les jetons, les médias sociaux et l'authentification de l'API, et prend en charge la fonctionnalité "Remember Me" et le contrôle d'accès basé sur les rôles. Surtout, la garde améliore, et non les remplace, les mécanismes de sécurité des symfony existants; Des méthodes comme form_login restent fonctionnelles.

Easier Authentication with Guard in Symfony 3

Cet article démontre une authentification de base de base nécessitant un accès ROLE_ADMIN. Bien que l'authentification traditionnelle de la forme reste viable, l'approche rationalisée de Guard est mise en évidence. Les mêmes principes s'appliquent à d'autres méthodes d'authentification. Un exemple d'application Symfony utilisant l'authentification du garde est disponible via [ce référentiel] (link_to_repository_here - remplacer par un lien réel si disponible).

Configuration de sécurité

Une configuration de sécurité fonctionnelle nécessite une classe utilisateur (représentant des données utilisateur) et un utilisateur (récupération des données utilisateur). Pour plus de simplicité, nous utiliserons le fournisseur d'utilisateurs InMemory avec la classe d'utilisateurs par défaut de Symfony. Le fichier security.yml commence comme suit:

security:
    providers:
        in_memory:
            memory:
                users:
                    admin:
                        password: admin
                        roles: 'ROLE_ADMIN'

(reportez-vous au site Web de Symfony pour des détails complets sur le fichier security.yml.)

Le pare-feu est défini sous la clé firewalls:

        secured_area:
            anonymous: ~
            logout:
                path:   /logout
                target: /
            guard:
                authenticators:
                    - form_authenticator

Cela permet un accès anonyme et spécifie /logout comme chemin de déconnexion. La clé guard désigne form_authenticator (notre nom de service) comme l'authentificateur.

Les règles d'accès sont spécifiées:

    access_control:
            - { path: ^/login, roles: IS_AUTHENTICATED_ANONYMOUSLY }
            - { path: ^/, roles: ROLE_ADMIN }

seuls les utilisateurs non authentifiés peuvent accéder à /login; Tous les autres chemins nécessitent ROLE_ADMIN.

Contrôleur de connexion

Le formulaire de connexion et le contrôleur sont définis dans le DefaultController:

  /**
   * @Route("/login", name="login")
   */
  public function loginAction(Request $request)
  {
    // ... (Existing code to handle user and authentication error) ...
  }

Cette action affiche un formulaire de connexion de base (rendu par un modèle de brindille).

Guard Authenticator Service

Le service form_authenticator est défini dans services.yml:

services:
    form_authenticator:
          class: AppBundle\Security\FormAuthenticator
          arguments: ["@router"]

La classe FormAuthenticator (détaillée ci-dessous) étend AbstractGuardAuthenticator:

namespace AppBundle\Security;

// ... (Import statements) ...

class FormAuthenticator extends AbstractGuardAuthenticator
{
    // ... (Methods: getCredentials, getUser, checkCredentials, onAuthenticationSuccess, onAuthenticationFailure, start, supportsRememberMe) ...
}

Cette classe met en œuvre le pipeline d'authentification du garde:

  • getCredentials(): extrait les informations d'identification des demandes de poste à /login.
  • getUser(): récupère l'utilisateur en fonction du nom d'utilisateur.
  • checkCredentials(): Vérifie le mot de passe contre le mot de passe stocké.
  • onAuthenticationSuccess(): redirige vers la page d'accueil sur une connexion réussie.
  • onAuthenticationFailure(): redirige vers la page de connexion avec les messages d'erreur.
  • start(): redirige vers la page de connexion lorsque l'authentification est requise.
  • supportsRememberMe(): indique si la fonctionnalité "souvenir de moi" est prise en charge.

Conclusion

Cela montre un système de connexion fonctionnel à l'aide du composant de garde. Plusieurs authentificateurs peuvent coexister, nécessitant une spécification de point d'entrée. Compléments de garde, et non remplacés, fonctionnalités de sécurité Symfony existantes.

Questions fréquemment posées (FAQ)

La section FAQ fournie propose des explications détaillées de divers aspects de l'authentification de la garde, y compris ses différences par rapport aux autres méthodes, les options de personnalisation, la gestion des rôles, le codage des mots de passe et son utilisation avec des bases de données et l'authentification sociale. Ces réponses sont complètes et traitent des préoccupations communes.

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
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
Comment PHP identifie-t-il la session d'un utilisateur?Comment PHP identifie-t-il la session d'un utilisateur?May 01, 2025 am 12:23 AM

Phpidentifiesauser'sessionusingssse cookiesand sessionids.1) whenSession_start () est calculé, phpgeneratesauquesseSessionIdStoredInacookIenameDPhpSesssIdonUser'sbrowser.2) thisIdallowsphptoreTrrieSeSessionDatafromTeserver.

Quelles sont les meilleures pratiques pour sécuriser les séances PHP?Quelles sont les meilleures pratiques pour sécuriser les séances PHP?May 01, 2025 am 12:22 AM

La sécurité des sessions PHP peut être obtenue grâce aux mesures suivantes: 1. Utilisez Session_RegeReate_ID () pour régénérer l'ID de session lorsque l'utilisateur se connecte ou est une opération importante. 2. Cryptez l'ID de session de transmission via le protocole HTTPS. 3. Utilisez session_save_path () pour spécifier le répertoire sécurisé pour stocker les données de session et définir correctement les autorisations.

Où les fichiers de session PHP sont-ils stockés par défaut?Où les fichiers de session PHP sont-ils stockés par défaut?May 01, 2025 am 12:15 AM

PhpSessionFilesArestorentheDirectorySpecifiedSession.save_path, généralement / tmponunix-likesystemsorc: \ windows \ temponwindows.tocustomzethis: 1) usession_save_path () tosetacustomDirectory, astumeit'swrit

Comment récupérer les données d'une session PHP?Comment récupérer les données d'une session PHP?May 01, 2025 am 12:11 AM

ToretrrievedatafromaphpSession, startTheSessionwithSession_start () et accessvariablesInthe $ _sessionArray.forexample: 1) startTheSession: session_start (). 2) récupéré: $ username = $ _ session ['userSeger']; echo "bienvenue,". $ Username;..

Comment pouvez-vous utiliser des sessions pour mettre en œuvre un panier?Comment pouvez-vous utiliser des sessions pour mettre en œuvre un panier?May 01, 2025 am 12:10 AM

Les étapes pour construire un système de panier d'achat efficace à l'aide de sessions comprennent: 1) Comprendre la définition et la fonction de la session. La session est un mécanisme de stockage côté serveur utilisé pour maintenir l'état de l'utilisateur entre les demandes; 2) Implémenter la gestion de session de base, comme l'ajout de produits au panier; 3) développer une utilisation avancée, soutenant la gestion de la quantité de produits et la suppression; 4) Optimiser les performances et la sécurité, en persistant les données de session et en utilisant des identifiants de session sécurisés.

Comment créez-vous et utilisez-vous une interface dans PHP?Comment créez-vous et utilisez-vous une interface dans PHP?Apr 30, 2025 pm 03:40 PM

L'article explique comment créer, mettre en œuvre et utiliser des interfaces dans PHP, en se concentrant sur leurs avantages pour l'organisation du code et la maintenabilité.

Quelle est la différence entre crypte () et mot de passe_hash ()?Quelle est la différence entre crypte () et mot de passe_hash ()?Apr 30, 2025 pm 03:39 PM

L'article traite des différences entre crypt () et mot de passe_hash () dans PHP pour le hachage de mot de passe, en se concentrant sur leur implémentation, leur sécurité et leur aptitude aux applications Web modernes.

Comment pouvez-vous prévenir les scripts inter-sites (XSS) en PHP?Comment pouvez-vous prévenir les scripts inter-sites (XSS) en PHP?Apr 30, 2025 pm 03:38 PM

L'article discute de la prévention des scripts inter-sites (XSS) dans PHP par validation d'entrée, en codage de sortie et en utilisant des outils comme OWASP ESAPI et Purificateur HTML.

See all articles

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

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Version crackée d'EditPlus en chinois

Version crackée d'EditPlus en chinois

Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code

PhpStorm version Mac

PhpStorm version Mac

Le dernier (2018.2.1) outil de développement intégré PHP professionnel

Listes Sec

Listes Sec

SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.

Navigateur d'examen sécurisé

Navigateur d'examen sécurisé

Safe Exam Browser est un environnement de navigation sécurisé permettant de passer des examens en ligne en toute sécurité. Ce logiciel transforme n'importe quel ordinateur en poste de travail sécurisé. Il contrôle l'accès à n'importe quel utilitaire et empêche les étudiants d'utiliser des ressources non autorisées.

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP