原因:无法在spring security中将null或空值传递给构造函数

Aks*_*A K 2 spring spring-security

当我尝试通过LDAP从数据库验证用户时收到以下错误.

Reason: Cannot pass null or empty values to constructor.
Run Code Online (Sandbox Code Playgroud)

谁能告诉我我做错了什么?

<?xml version="1.0" encoding="UTF-8"?>  
<beans:beans xmlns="http://www.springframework.org/schema/security" 
xmlns:beans="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd  
http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-3.1.xsd">  

<http auto-config="true">
<intercept-url pattern="/**" access="ROLE_USER,ROLE_ADMIN" />
<intercept-url pattern="/administrator.htm" access="ROLE_ADMIN" />
<!-- <form-login login-page="/dashboard.htm" default-target-url="/dashboard.htm" authentication-failure-url="/ExceptionPage.jsp" /> -->
<form-login/>
</http>

<authentication-manager>
<authentication-provider>
<!--   <user-service>
<user name="20022263" password="da" authorities="ROLE_USER" />
<user name="20039004" password="da" authorities="ROLE_ADMIN" />
</user-service> -->
   <jdbc-user-service data-source-ref="dataSource" 
users-by-username-query="SELECT a.GLOBALID AS username, a.PASSWORD AS password, a.Enabled AS enabled FROM EU_MAS_TBUSER a WHERE a.GLOBALID=?" 
 authorities-by-username-query="select eu.USERNAME AS username, r.ACCESSROLEID AS authority from EU_MAS_TBUSER eu, EU_MAS_TBUSERS_ROLE r where eu.GLOBALID = r.GLOBALID and eu.GLOBALID=?" 
 role-prefix="ROLE_"/>   
</authentication-provider>

 </authentication-manager>

</beans:beans>
Run Code Online (Sandbox Code Playgroud)

Sha*_*eep 20

产生异常的实际行在这里.创建用户对象的相关代码在此处.

所以我最好的猜测是,数据库中的用户有一个空密码字段.

请注意,如果您发布这样的错误,如果您从服务器日志中提供堆栈跟踪和相关的调试输出,则更容易回答.