Catch possible NullPointerException
Some maps may throw a NullPointerException when get is called with null. This commit catches the exceptions and just leaves the delegate null. Fixes gh-4936
This commit is contained in:
parent
718052932a
commit
2b66793535
|
@ -116,6 +116,7 @@ import java.util.Map;
|
|||
* @see org.springframework.security.crypto.factory.PasswordEncoderFactories
|
||||
*
|
||||
* @author Rob Winch
|
||||
* @author Michael Simons
|
||||
* @since 5.0
|
||||
*/
|
||||
public class DelegatingPasswordEncoder implements PasswordEncoder {
|
||||
|
@ -190,7 +191,11 @@ public class DelegatingPasswordEncoder implements PasswordEncoder {
|
|||
return true;
|
||||
}
|
||||
String id = extractId(prefixEncodedPassword);
|
||||
PasswordEncoder delegate = this.idToPasswordEncoder.get(id);
|
||||
PasswordEncoder delegate = null;
|
||||
try {
|
||||
delegate = this.idToPasswordEncoder.get(id);
|
||||
} catch(NullPointerException e) {
|
||||
}
|
||||
if(delegate == null) {
|
||||
return this.defaultPasswordEncoderForMatches
|
||||
.matches(rawPassword, prefixEncodedPassword);
|
||||
|
|
|
@ -33,6 +33,7 @@ import static org.mockito.Mockito.when;
|
|||
|
||||
/**
|
||||
* @author Rob Winch
|
||||
* @author Michael Simons
|
||||
* @since 5.0
|
||||
*/
|
||||
@RunWith(MockitoJUnitRunner.class)
|
||||
|
@ -46,6 +47,9 @@ public class DelegatingPasswordEncoderTests {
|
|||
@Mock
|
||||
private PasswordEncoder invalidId;
|
||||
|
||||
@Mock
|
||||
private Map<String, PasswordEncoder> throwingDelegates;
|
||||
|
||||
private String bcryptId = "bcrypt";
|
||||
|
||||
private String rawPassword = "password";
|
||||
|
@ -167,6 +171,21 @@ public class DelegatingPasswordEncoderTests {
|
|||
verifyZeroInteractions(this.bcrypt, this.noop);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void matchesWhenIdIsNullThenFalse() {
|
||||
when(this.throwingDelegates.containsKey(this.bcryptId)).thenReturn(true);
|
||||
when(this.throwingDelegates.get(this.bcryptId)).thenReturn(this.bcrypt);
|
||||
when(this.throwingDelegates.get(null)).thenThrow(NullPointerException.class);
|
||||
|
||||
DelegatingPasswordEncoder passwordEncoder = new DelegatingPasswordEncoder(this.bcryptId, throwingDelegates);
|
||||
|
||||
assertThatThrownBy(() -> passwordEncoder.matches(this.rawPassword, this.rawPassword))
|
||||
.isInstanceOf(IllegalArgumentException.class)
|
||||
.hasMessage("There is no PasswordEncoder mapped for the id \"null\"");
|
||||
|
||||
verifyZeroInteractions(this.bcrypt, this.noop);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void matchesWhenNullIdThenDelegatesToInvalidId() {
|
||||
this.delegates.put(null, this.invalidId);
|
||||
|
|
Loading…
Reference in New Issue