Récupération des détails de l'utilisateur actif
Lors de l'accès à l'utilisateur actuellement authentifié dans les méthodes du contrôleur, l'obtention de l'implémentation UserDetails nécessitait traditionnellement d'accéder au contexte et de lancer le principal d'un objet User.
WebArgumentResolver Solution
Pour une approche plus élégante, envisagez d'implémenter un WebArgumentResolver qui prend la responsabilité de résoudre les objets User annotés avec une annotation personnalisée, telle que @ActiveUser. Ce résolveur peut renvoyer conditionnellement l'utilisateur en fonction de la présence de l'annotation et du type d'argument de méthode.
Solution Spring 3.1 : HandlerMethodArgumentResolver
Si vous utilisez Spring 3.1 ou plus tard, un HandlerMethodArgumentResolver est préféré. Il prend en charge la vérification de l'annotation @ActiveUser et le renvoi de l'utilisateur si les conditions sont remplies.
Solution Spring Security 3.2 : @AuthenticationPrincipal
Spring Security 3.2 a introduit l'annotation @AuthenticationPrincipal , qui simplifie le processus en permettant l'injection directe de l'objet utilisateur dans les méthodes du contrôleur. Pour utiliser cette annotation, enregistrez AuthenticationPrincipalArgumentResolver dans la configuration Spring.
Pour les anciennes versions de Spring Security :
Si vous utilisez une version antérieure de Spring Security ou si vous préférez une version personnalisée approche, envisagez de mettre en œuvre la solution WebArgumentResolver décrite ci-dessus.
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!