Class AuthenticationPrincipalArgumentResolver
- java.lang.Object
- 
- org.springframework.security.messaging.context.AuthenticationPrincipalArgumentResolver
 
- 
- All Implemented Interfaces:
- org.springframework.messaging.handler.invocation.HandlerMethodArgumentResolver
 
 public final class AuthenticationPrincipalArgumentResolver extends java.lang.Object implements org.springframework.messaging.handler.invocation.HandlerMethodArgumentResolverAllows resolving theAuthentication.getPrincipal()using theAuthenticationPrincipalannotation. For example, the followingController:@Controller public class MyController { @MessageMapping("/im") public void im(@AuthenticationPrincipal CustomUser customUser) { // do something with CustomUser } }Will resolve the CustomUser argument using Authentication.getPrincipal()from theSecurityContextHolder. If theAuthenticationorAuthentication.getPrincipal()is null, it will return null. If the types do not match, null will be returned unlessAuthenticationPrincipal.errorOnInvalidType()is true in which case aClassCastExceptionwill be thrown.Alternatively, users can create a custom meta annotation as shown below: @Target({ ElementType.PARAMETER }) @Retention(RetentionPolicy.RUNTIME) @AuthenticationPrincipal public @interface CurrentUser { }The custom annotation can then be used instead. For example: @Controller public class MyController { @MessageMapping("/im") public void im(@CurrentUser CustomUser customUser) { // do something with CustomUser } }- Since:
- 4.0
 
- 
- 
Constructor SummaryConstructors Constructor Description AuthenticationPrincipalArgumentResolver()
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description java.lang.ObjectresolveArgument(org.springframework.core.MethodParameter parameter, org.springframework.messaging.Message<?> message)booleansupportsParameter(org.springframework.core.MethodParameter parameter)
 
- 
- 
- 
Method Detail- 
supportsParameterpublic boolean supportsParameter(org.springframework.core.MethodParameter parameter) - Specified by:
- supportsParameterin interface- org.springframework.messaging.handler.invocation.HandlerMethodArgumentResolver
 
 - 
resolveArgumentpublic java.lang.Object resolveArgument(org.springframework.core.MethodParameter parameter, org.springframework.messaging.Message<?> message)- Specified by:
- resolveArgumentin interface- org.springframework.messaging.handler.invocation.HandlerMethodArgumentResolver
 
 
- 
 
-