在我们进行登录时,如果用户数据来自不同的表,在一个表中查不到就去另一个表查,我们就需要配置多个数据源
经过(五)的分析,我们知道了认证需要经过ProviderManager,ProviderManager对应多个AuthenticationProvider,而每个AuthenticationProvider都对应一个UserDetailsService,每个UserDetailsService对应一个数据源
我们只需要编写多个UserDetailsService即可,我们以账号/密码登录方式为例
@Configuration
public class SecurityConfig extends WebSecurityConfigurerAdapter{
@Autowired
MyUserDetailsService1 userDetailsService1;
@Autowired
MyUserDetailsService2 userDetailsService2;
@Override
@Bean
public AuthenticationManager authenticationManagerBean() throws Exception{
//创建多个AuthenticationProvider,并为他们注入UserDetailsService
DaoAuthenticationProvider dao1=new DaoAuthenticationProvider();
dao1.setUserDetailsService(userDetailsService1);
DaoAuthenticationProvider dao2=new DaoAuthenticationProvider();
dao2.setUserDetailsService(userDetailsService2);
//创建ProviderManager,并注入AuthenticationProvider
ProviderManager manager=new ProviderManager(dao1,dao2);
return manager;
}
}