繁体   English   中英

使用loadUserByUsername时发生NullPointerException

[英]NullPointerException while using loadUserByUsername

这是从此处开始的Spring Security登录示例。 我将注释配置更改为XML,并对应该指向的URL进行了很少的更改。我能够使用db中的凭据成功登录。 如果我输入了错误的密码,则会收到无效的消息。 但是,如果我输入的用户名不在db中,或者只提交没有值的用户名,则会得到nullpointerexception。

java.lang.NullPointerException
    com.xxxx.service.CustomUserDetailsService.loadUserByUsername(CustomUserDetailsService.java:37)
    sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    java.lang.reflect.Method.invoke(Method.java:606)

CustomUserDetailsS​​ervice.java

@Service
@Transactional(readOnly=true)
public class CustomUserDetailsService implements UserDetailsService {

    @Autowired
    private LoginDAO loginDAO;

    public UserDetails loadUserByUsername(String userName)
            throws UsernameNotFoundException {

        com.xxxx.model.Login domainUser = loginDAO.getUser(userName);

        boolean enabled = true;
        boolean accountNonExpired = true;
        boolean credentialsNonExpired = true;
        boolean accountNonLocked = true;

        return new User(
                domainUser.getUserName(), // line 37
                domainUser.getPassword(),
                enabled,
                accountNonExpired,
                credentialsNonExpired,
                accountNonLocked,
                getAuthorities(domainUser.getRole().getId())
                ); 

            }

            public Collection<? extends GrantedAuthority> getAuthorities(Integer role) {
            List<GrantedAuthority> authList = getGrantedAuthorities(getRoles(role));
            return authList;
            }

            public List<String> getRoles(Integer role) {

                List<String> roles = new ArrayList<String>();

                if (role.intValue() == 1) {
                roles.add("ROLE_MODERATOR");
                roles.add("ROLE_ADMIN");
                } else if (role.intValue() == 2) {
                roles.add("ROLE_MODERATOR");
                }
                return roles;
                }
            public static List<GrantedAuthority> getGrantedAuthorities(List<String> roles) {
                List<GrantedAuthority> authorities = new ArrayList<GrantedAuthority>();

                for (String role : roles) {
                authorities.add(new GrantedAuthorityImpl (role));
                }
                return authorities;
                }
}

弹簧security.xml文件

<http auto-config="true">

<intercept-url pattern="/success" access="ROLE_MODERATOR" />
<intercept-url pattern="/success" access="ROLE_ADMIN" />

<form-login login-page="/login.html"
default-target-url="/success.html"
authentication-failure-url="/error.html" />
<logout logout-success-url="/login.html" />

</http>

<authentication-manager>
<authentication-provider user-service-ref="customUserDetailsService">
<password-encoder hash="plaintext" />
</authentication-provider>
</authentication-manager>

</beans:beans> 

请有人指出我做错了什么。

编辑:LoginDAOImpl.java

@Repository
public class LoginDAOImpl implements LoginDAO {

    @Autowired
    private SessionFactory sessionFactory;

    private Session openSession() {
        return sessionFactory.getCurrentSession();
    }

    public Login getUser(String userName) {
        List<Login> loginList = new ArrayList<Login>();
        Query query = openSession().createQuery(
                "from Login l where l.userName = :userName");
        query.setParameter("userName", userName);
        loginList = query.list();
        if (loginList.size() > 0)
            return loginList.get(0);
        else
            return null;    
    }
}

问题是您正在尝试访问null Login对象的userName字段。

如我所见,如果用户名不在数据库中,则您将从DAO返回null ,但您没有在Service中检查返回值。

因此,在创建新的User实例之前,请检查返回的Login 是否为null 如果为null ,则应抛出UsernameNotFoundException

在您的应用程序上下文(app-context.xml文件)中尝试此操作,或尝试其他xml文件。

<context:annotation-config/>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM