java.lang.IllegalArgumentException: There is no PasswordEncoder mapped for the id “null”

别裁伪体亲风雅,转益多师是汝师。这篇文章主要讲述java.lang.IllegalArgumentException: There is no PasswordEncoder mapped for the id “null”相关的知识,希望能为你提供帮助。
在spring security中设置默认的登录人的信息,遇到的异常信息:

java.lang.IllegalArgumentException: There is no PasswordEncoder mapped for the id “ null”

有些版本不要求这样子做,所以就不会有该问题的发生, 我现在用的是5.0版本,强制要求提供一个,所以我们就给一个PasswordEncoder给他. 我们也可以使用Spring自带的PasswordEncoder.为了方便起见,我们以明文形式存密码在后台,故使用自定义PasswordEncoder

自定义passwordEncoder
public class MyPasswordEncoder implements PasswordEncoder { @Override public String encode(CharSequence arg0) { return arg0.toString(); } @Override public boolean matches(CharSequence arg0, String arg1) { return arg1.equals(arg0.toString()); } }

应用自定义编码器
@Configuration @EnableWebSecurity public class WebSecurityConfig extends WebSecurityConfigurerAdapter { @Override protected void configure(AuthenticationManagerBuilder auth) throws Exception { auth .inMemoryAuthentication() .passwordEncoder(new MyPasswordEncoder())//在此处应用自定义PasswordEncoder .withUser("user") .password("password") .roles("USER"); } }

自带编码器
@Bean public PasswordEncoder passwordEncoder() { return new BCryptPasswordEncoder(); }

别忘了在注册用户的地方添加编码器加密
【java.lang.IllegalArgumentException: There is no PasswordEncoder mapped for the id “null”】增加一个passwordEncoder就可以解决这种异常

    推荐阅读