java - 在身份验证之前检查用户启用状态 - Spring Security

标签 java spring spring-security

在我的 loadByUserName() 方法中,我通过邮件找到用户。目前,我的 User 类使用 isEnabled() 方法实现 UserDetails 来检查用户是否已启用。但是,在身份验证之前会检查此启用标志,这样任何人都可以查明其他用户的帐户是否已启用,无论使用什么密码。有没有办法在身份验证后检查启用标志?

我的用户类别:

@Entity
public class User implements UserDetails {

    @Column(name = "ativo")
    private Boolean ativo;

    //... some attributes, getters and setters

    @Override
    public boolean isEnabled() {
        if(this.ativo){
            return true;
        }else{
            return false;
        }
    }
}

我的 loadUserByUsername() 方法:

@Override
public User loadUserByUsername(String mail) {
    List<User> users = manager.findUserByMail(String mail);

    if (pessoas.isEmpty()) {
        throw new RuntimeException("User not found!");
    } 
    return users.get(0);
}

我更改了默认消息,以防凭据错误或用户被禁用:

消息.属性:

AbstractUserDetailsAuthenticationProvider.badCredentials = Mail/Password is incorrect!
AbstractUserDetailsAuthenticationProvider.disabled = User disabled!

最佳答案

我想以一种不仅可以在这种情况下使用而且可以在其他类似情况下使用的方式来回答这个问题。

应用程序的用户如何理解代码中发生的情况?他对你的代码一无所知,但我们(作为开发人员)是告诉他们幕后发生了什么以及使用 message.properties 首先执行哪个方法的人。

如果你不通知他们,他们就没有任何办法知道哪个方法首先执行。因此您可以将这两个属性更改为同一条消息,例如“密码不正确”。

这正是 Linux 操作系统中发生的情况,当你想使用不存在的用户名登录时,linux 不会告诉你用户不存在,即使用户不存在它也会让你进入密码,然后通知您密码不正确。因为通常我们不应该向进行恶意行为的人提供额外的信息。一般来说,此类信息对于开发人员和监控目的非常有帮助。因此您应该找到一种方法来记录此类信息以供将来使用,但不要将它们显示给用户。

关于java - 在身份验证之前检查用户启用状态 - Spring Security,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62185892/

相关文章:

java - 从 Java 中对象的阻塞垃圾回收中排除引用

spring - 使用 Grails/Groovy 注入(inject)构造函数参数 Spring 资源文件

java - 如何将 "include"Spring Security配置到应用程序中

java - auth Spring安全java配置

java - collections.shuffle 中的默认随机源

java - 更新 build.gradle 会从类路径中删除库

java - Java 中的获取和设置(这里是新手程序员)

Java Spring Boot 测试 : How to exclude java configuration class from test context

java - JSP 页面在浏览器中作为文本

java - AbstractRoutingDataSource 在运行时更改映射