Ola.
Estava implementando uma solucao com num projeto pessoal e fui utilizar a parte de autenticacao e configuracao de seguranca desse curso. Implementei tudo igual e me saia esse erro :
java.lang.IllegalArgumentException: There is no PasswordEncoder mapped for the id "null"
Para confirmar descarreguei o projeto completo (compila e esta rodando) da alura e continua saindo o mesmo erro.
No Postman ele nao dispara o erro e fica no status 401 unautorazed criei a requesicao POST: http://localhost:8080/auth Parametros:
{
"email": "aluno@email.com",
"senha": "123456"
}
O erro dispara no console do eclipse se tento logar pelo navegador.
Aqui esta o codigo da classe SecurityConfigurations :
@Override
@Bean
protected AuthenticationManager authenticationManager() throws Exception {
return super.authenticationManager();
}
//Configuracoes de autenticacao
@Override
protected void configure(AuthenticationManagerBuilder auth) throws Exception {
auth.userDetailsService(autenticacaoService).passwordEncoder(new BCryptPasswordEncoder());
}
//Configuracoes de autorizacao
@Override
protected void configure(HttpSecurity http) throws Exception {
http.authorizeRequests()
.antMatchers(HttpMethod.GET, "/topicos").permitAll()
.antMatchers(HttpMethod.GET, "/topicos/*").permitAll()
.antMatchers(HttpMethod.POST, "/auth").permitAll()
.antMatchers(HttpMethod.GET, "/actuator/**").permitAll()
.antMatchers(HttpMethod.DELETE, "/topicos/*").hasRole("MODERADOR")
.anyRequest().authenticated()
.and().csrf().disable()
.sessionManagement().sessionCreationPolicy(SessionCreationPolicy.STATELESS)
.and().addFilterBefore(new AutenticacaoViaTokenFilter(tokenService, usuarioRepository), UsernamePasswordAuthenticationFilter.class);
}
Nao sei o que pode passei o dia todo tentando buscar uma solucao e nada.