Class InMemoryUserDetailsManager
java.lang.Object
org.springframework.security.provisioning.InMemoryUserDetailsManager
- All Implemented Interfaces:
UserDetailsPasswordService,UserDetailsService,UserDetailsManager
public class InMemoryUserDetailsManager
extends Object
implements UserDetailsManager, UserDetailsPasswordService
Non-persistent implementation of
UserDetailsManager which is backed by an
in-memory map.
Mainly intended for testing and demonstration purposes, where a full blown persistent system isn't required.
- Since:
- 3.1
-
Field Summary
FieldsFields inherited from interface org.springframework.security.core.userdetails.UserDetailsPasswordService
NOOP -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidchangePassword(String oldPassword, String newPassword) Modify the current user's password.voidcreateUser(UserDetails user) Create a new user with the supplied details.voiddeleteUser(String username) Remove the user with the given login name from the system.loadUserByUsername(String username) Locates the user based on the username.voidsetAuthenticationManager(AuthenticationManager authenticationManager) voidsetSecurityContextHolderStrategy(SecurityContextHolderStrategy securityContextHolderStrategy) Sets theSecurityContextHolderStrategyto use.updatePassword(UserDetails user, @Nullable String newPassword) Modify the specified user's password.voidupdateUser(UserDetails user) Update the specified user.booleanuserExists(String username) Check if a user with the supplied login name exists in the system.
-
Field Details
-
logger
protected final org.apache.commons.logging.Log logger
-
-
Constructor Details
-
InMemoryUserDetailsManager
public InMemoryUserDetailsManager() -
InMemoryUserDetailsManager
-
InMemoryUserDetailsManager
-
InMemoryUserDetailsManager
-
-
Method Details
-
createUser
Description copied from interface:UserDetailsManagerCreate a new user with the supplied details.- Specified by:
createUserin interfaceUserDetailsManager
-
deleteUser
Description copied from interface:UserDetailsManagerRemove the user with the given login name from the system.- Specified by:
deleteUserin interfaceUserDetailsManager
-
updateUser
Description copied from interface:UserDetailsManagerUpdate the specified user.- Specified by:
updateUserin interfaceUserDetailsManager
-
userExists
Description copied from interface:UserDetailsManagerCheck if a user with the supplied login name exists in the system.- Specified by:
userExistsin interfaceUserDetailsManager
-
changePassword
Description copied from interface:UserDetailsManagerModify the current user's password. This should change the user's password in the persistent user repository (database, LDAP etc).- Specified by:
changePasswordin interfaceUserDetailsManager- Parameters:
oldPassword- current password (for re-authentication if required)newPassword- the password to change to
-
updatePassword
Description copied from interface:UserDetailsPasswordServiceModify the specified user's password. This should change the user's password in the persistent user repository (database, LDAP etc).- Specified by:
updatePasswordin interfaceUserDetailsPasswordService- Parameters:
user- the user to modify the password fornewPassword- the password to change to, encoded by the configuredPasswordEncoder- Returns:
- the updated UserDetails with the new password
-
loadUserByUsername
Description copied from interface:UserDetailsServiceLocates the user based on the username. In the actual implementation, the search may possibly be case sensitive, or case insensitive depending on how the implementation instance is configured. In this case, theUserDetailsobject that comes back may have a username that is of a different case than what was actually requested..- Specified by:
loadUserByUsernamein interfaceUserDetailsService- Parameters:
username- the username identifying the user whose data is required.- Returns:
- a fully populated user record (never
null) - Throws:
UsernameNotFoundException- if the user could not be found or the user has no GrantedAuthority
-
setSecurityContextHolderStrategy
public void setSecurityContextHolderStrategy(SecurityContextHolderStrategy securityContextHolderStrategy) Sets theSecurityContextHolderStrategyto use. The default action is to use theSecurityContextHolderStrategystored inSecurityContextHolder.- Since:
- 5.8
-
setAuthenticationManager
-