सेवा परत
आपको एक अलग service
बनाना होगा org.springframework.security.core.userdetails.UserDetailsService
को लागू करना और इसे AuthenticationManagerBuilder
. के अंदर इंजेक्ट करें ।
@Component
public class SecUserDetailsService implements UserDetailsService{
@Autowired
private UserRepository userRepository;
@Override
public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
/*Here add user data layer fetching from the MongoDB.
I have used userRepository*/
User user = userRepository.findByUsername(username);
if(user == null){
throw new UsernameNotFoundException(username);
}else{
UserDetails details = new SecUserDetails(user);
return details;
}
}
}
मॉडल
UserDetails
अमल भी करना चाहिए। यह पीओजेओ है जो उपयोगकर्ता को वसंत द्वारा प्रमाणित विवरण रखेगा। जैसा कि मैंने किया है, आप इसके अंदर लिपटे हुए अपने एंटिटी डेटा ऑब्जेक्ट को शामिल कर सकते हैं।
public class SecUserDetails implements UserDetails {
private User user;
public SecUserDetails(User user) {
this.user = user;
}
......
......
......
}
सुरक्षा कॉन्फ़िगरेशन
हमारे द्वारा पहले बनाई गई सेवा को ऑटोवायर करें और इसे AuthenticationManagerBuilder
. के अंदर सेट करें
@Configuration
@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {
@Autowired
SecUserDetailsService userDetailsService ;
@Autowired
public void configAuthBuilder(AuthenticationManagerBuilder builder) throws Exception {
builder.userDetailsService(userDetailsService);
}
}