Maison  >  Article  >  Java  >  Comment récupérer l’utilisateur actuel dans les applications Spring ?

Comment récupérer l’utilisateur actuel dans les applications Spring ?

Linda Hamilton
Linda Hamiltonoriginal
2024-11-06 10:18:02873parcourir

How to Retrieve the Current User in Spring Applications?

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!

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