@Autowire не работает в Spring безопасности Пользовательский поставщик проверки подлинности
У нас есть приложение Spring MVC. Мы пытаемся интегрировать в нее защиту Spring.
Мы создали собственный поставщик аутентификации, который будет выполнять проверку подлинности.
Ниже приведен код моего собственного поставщика проверки подлинности.
public class CustomAuthenticationProvider extends DaoAuthenticationProvider {
@Autowired
private AuthenticationService authenticationService;
@Override
public Authentication authenticate(Authentication authentication) {
CustomAuthenticationToken auth = (CustomAuthenticationToken) authentication;
String username = String.valueOf(auth.getPrincipal());
String password = String.valueOf(auth.getCredentials());
try {
Users user = new User();
user.setUsername(username);
user.setPassword(PasswordUtil.encrypt(password));
user = authenticationService.validateLogin(user);
return auth;
} catch (Exception e) {
throw new BadCredentialsException("Username/Password does not match for " + username);
}
}
@Override
public boolean supports(Class<? extends Object> authentication) {
return (CustomAuthenticationToken.class.isAssignableFrom(authentication));
}
}
Здесь я получаю исключение NullpointerException в следующей строке
user = authenticationService.validateLogin(user);
Служба аутентификации не получает аутсорсинг в специализированном поставщике проверки подлинности. Хотя тот же сервис authenticationService автообновлен таким же образом в моем MVC-контроллере.
Это потому, что поставщик проверки подлинности является компонентом безопасности Spring?
Ниже мой web.xml
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>
/WEB-INF/spring/myApp-security.xml
</param-value>
</context-param>
<servlet>
<servlet-name>myApp</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/spring/myApp-servlet.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>myApp</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<filter>
<filter-name>springSecurityFilterChain</filter-name>
<filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
</filter>
<filter-mapping>
<filter-name>springSecurityFilterChain</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
Изменить 1: -
Я добавил следующие строки в мой конфигурационный файл безопасности Spring.
<beans:bean id="customAuthenticationProvider" class="com.myApp.security.provider.CustomAuthenticationProvider">
<beans:property name="userDetailsService" ref="userDetailsService"/>
</beans:bean>
Пожалуйста, помогите как автоушилить мои классы обслуживания в Spring компонентах безопасности?
Ответы
Ответ 1
Возможно, автосогласование постпроцессора не включено в корневом контексте приложения (но включено в контексте DispatcherServlet
как побочный эффект <mvc:annotation-driven>
или <context:component-scan>
).
Вы можете включить его, добавив <context:annotation-config>
в myApp-security.xml
.
Ответ 2
Я столкнулся с этой проблемой и пришел к выводу, что при аутсорсинге безопасность spring работала с совершенно другим экземпляром классов. Чтобы решить эту проблему, я импортировал конфигурацию безопасности в конфигурацию spring mvc, как показано ниже.
Это позволило spring безопасности разделить контекст с моим spring mvc.
<import resource="myapp-security.xml" />
Ответ 3
Вы используете элемент <debug/>
? Если да, попробуйте удалить, чтобы проверить, исправляет ли ваша проблема SEC-1885 предотвращает работу @Autowired
при использовании <debug/>
.
Ответ 4
Я столкнулся с той же проблемой и исправил ее.
Решение даже если u имеет @Autowired аннотацию, установленную для класса Service.
@Autowired
private AuthenticationService authenticationService;
Удалено определение bean в вашем диспетчере-servlet.xml, и оно будет работать.
<!--
<beans:bean id="customAuthenticationProvider" class="com.myApp.security.provider.CustomAuthenticationProvider">
<beans:property name="userDetailsService" ref="userDetailsService"/>
</beans:bean>
-->
и добавьте его в файл контекста безопасности
Ответ 5
вам нужно определить свой CustomAuthenticationProvider как spring bean (обычно в applicationContext.xml или applicationContext-security.xml, если он есть)
Ответ 6
Вы должны использовать
Вы не можете использовать, потому что ваш myApp-security.xml создает другой ApplicationContext, который не видит все автоустановки из вашего контекста, созданные myApp-servlet.xml