Spring Security用户登录时忽略大小写的问题

今天测试提了一个bug,用户名不区分大小写也能成功登录。

一开始以为是安全框架(Security)的问题

但实际上,security把登录的逻辑完全交给了loadUserByUsername方法

    @Override
    public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException{

        //查询数据库

    }

比如此时我数据库中的用户名为小写的 admin。

我尝试用大写用户名登录

可以看出,传给这个方法的参数依然是大写的,security没有动过这个变量。

继续向下走

发现即使是大写,也依然可以查询到数据。说明问题出在了数据库上。

当前数据库中用户名的编码排序规则为

utf8mb4_general_ci ,是忽略大小写的。将排序规则改为 大小写敏感的utf8mb4_bin即可。

再次尝试登录

问题解决了

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Spring Security是一个强大的开源框架,用于为Java Web应用提供安全功能,包括身份验证、授权和会话管理。用户登录Spring Security的核心功能之一,主要涉及以下几个步骤: 1. **配置**: - 在Spring Security配置文件(如application.properties或application.yml)中,设置URL路径前缀(`http`标签下的`form-login`或`http-basic`),定义认证器(`security:`标签下)。 2. **登录页面**: - Spring Security提供了内置的`login.jsp`页面,也可以自定义登录界面(使用`<form-login>`标签指定登录表单)。 3. **身份验证处理器**: - `AuthenticationManager`负责处理用户输入的用户名和密码,这通常是通过`AuthenticationProvider`接口实现的,如`DaoAuthenticationProvider`(数据库验证)或`UsernamePasswordAuthenticationToken`。 4. **认证拦截器**: - `UsernamePasswordAuthenticationFilter`负责拦截HTTP请求,验证用户凭证,并创建`Authentication`对象。 5. **会话管理**: - 用户成功登录后,Spring Security会创建一个会话,并管理其生命周期,直到会话过期或用户手动注销。 6. **访问控制**: - 使用`AccessDecisionManager`和`AccessDecisionVoter`来决定用户是否有权限访问特定资源,通过`@PreAuthorize`和`@PostAuthorize`注解在方法或控制器上进行权限控制。 7. **记住我功能**: - 可以配置`RememberMeServices`,让系统记住用户的登录状态,通常涉及`HttpSession`和Cookie。 相关问题--: 1. 如何在Spring Security中实现基于角色的访问控制? 2. 如何自定义Spring Security的登录页面? 3. 使用Spring Security如何防止CSRF攻击?

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值