关于Spring Security的一些坑(持续更新)

本文介绍了在Spring Boot项目中使用Spring Security遇到的一个常见问题,即在进行内存用户验证时遇到'IllegalArgumentException: There is no PasswordEncoder mapped for the id “null”'的错误。该错误由于Spring Security 5.0以后版本要求必须配置密码编码器导致。文中提供了两种解决方案:一是使用Spring自带的密码编码器,二是自定义passwordEncoder并配置到SecurityConfig中,从而成功完成登录功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题一

使用springboot,权限管理使用spring security,使用内存用户验证,但无响应报错:java.lang.IllegalArgumentException: There is no PasswordEncoder mapped for the id “null”

这个问题极其坑爹.

究其原因是因为我看的springboot的视频版本太老了导致的:

原先的代码:

    @Autowired
    public void configureGlobal(AuthenticationManagerBuilder auth) throws Exception {
   
   
        auth
                .inMemoryAuthentication()
                .withUser("admin").password("123456").roles("USER");
    }

如果单纯这样配置,必定报上面的错误。

原因在于Securuty5.0之后,强制性要求提供一个密码编码器才能通过验证,否则必报上面的空值异常

因此,多种解决方案

第一种,使用spring自带的:

此代码摘自官网

    @Bean
    @Override
    public UserDetailsService userDetailsService() {
   
   
        UserDetails user
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值