非常简单的场景:我正在使用 Spring 和 Spring Security,并且我试图将一个属性注入到我的 AuthenticationManager 使用的 AuthenticationProvider 中。我只是想到我可以将它连接到 applicationContext 中,但不确定这是否可行。
应用程序上下文.xml:
<http use-expressions="true">
<intercept-url pattern="/" access="permitAll" />
<intercept-url pattern="/**" access="hasRole('USER')"/>
<form-login login-page="/index" />
</http>
<authentication-manager alias="authenticationManager">
<authentication-provider ref="twitterAuthenticationProvider" />
</authentication-manager>
<beans:bean id="twitterAuthenticationProvider" class="com.bottlingday.model.auth.TwitterAuthenticationProvider" />
TwitterAuthenticationProvider:
public class TwitterAuthenticationProvider implements AuthenticationProvider
{
@Autowired
private AppEngineUserStore userStore;
static Log log = LogFactory.getLog(TwitterAuthenticationProvider.class.getName());
public void Test()
{
//userStore is always null here
log.info("test");
}
}
在我的控制器中,这失败了,因为 userStore 在 TwitterAuthenticationProvider 中是一个空引用:
Authentication authentication = this.authenticationManager.authenticate(authToken);
这是确切的错误:
java.lang.NullPointerException
at com.bottlingday.model.auth.TwitterAuthenticationProvider.authenticate(TwitterAuthenticationProvider.java:33)
at org.springframework.security.authentication.ProviderManager.authenticate(ProviderManager.java:156)
at com.bottlingday.auth.TwitterAuthController.OauthCallback(TwitterAuthController.java:129)
编辑:我正在使用自动装配,它适用于其他事情。如果我在 MVC 控制器中自动装配 AppEngineUserStore,它每次都会在那里。