활성 사용자의 UserDetails 검색
Spring 애플리케이션에서 컨트롤러로 작업할 때 활성 사용자의 세부 정보를 검색하려면 UserDetails 구현.
<code class="java">User activeUser = (User)SecurityContextHolder.getContext().getAuthentication().getPrincipal();</code>
이 접근 방식은 기능적이지만 종속성 주입을 사용하여 단순화할 수 있습니다.
@AuthenticationPrincipal 주석 사용
In Spring Security 3.2 이상에서는 @AuthenticationPrincipal 주석을 활용할 수 있습니다. 이 우아한 솔루션을 사용하면 UserDetails 개체를 컨트롤러나 메서드에 직접 주입할 수 있습니다.
<code class="java">public ModelAndView someRequestHandler(@AuthenticationPrincipal User activeUser) { ... }</code>
ArgumentResolvers 사용
Spring Security 3.2 이전 또는 사용자 정의가 필요한 경우 , 인수 해결 프로그램을 사용할 수 있습니다. CurrentUserWebArgumentResolver와 같은 WebArgumentResolver를 생성하여 UserDetails 객체를 자동으로 확인할 수 있습니다.
<code class="java">public class CurrentUserWebArgumentResolver implements WebArgumentResolver { @Override public Object resolveArgument(...) { if (...) { return (User) ((Authentication) principal).getPrincipal(); } else { return WebArgumentResolver.UNRESOLVED; } } }</code>
이 리졸버는 애플리케이션 구성에 등록되어야 합니다.
Spring 3.1: HandlerMethodArgumentResolver
Spring 3.1에서는 CurrentUserHandlerMethodArgumentResolver와 마찬가지로 HandlerMethodArgumentResolver를 권장합니다. 이는 WebArgumentResolver와 유사한 기능을 제공합니다.
<code class="java">public class CurrentUserHandlerMethodArgumentResolver implements HandlerMethodArgumentResolver { @Override public Object resolveArgument(...) { if (...) { return (User) ((Authentication) principal).getPrincipal(); } else { return WebArgumentResolver.UNRESOLVED; } } }</code>
이 해결 프로그램도 구성에 등록해야 합니다.
이러한 방법을 활용하면 다음에서 활성 사용자의 UserDetails를 우아하게 얻을 수 있습니다. Spring 애플리케이션 코드의 유지 관리성과 가독성을 향상시킵니다.
위 내용은 Spring 애플리케이션에서 활성 사용자의 UserDetails를 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!