UserDetailsService中Service或者Dao 使用@Autowired注入为NULL SpringBoot架构

网上有一些关于这个问题的答案,但都不是基于SpringBoot的,一想到SpringBoot还要配置XML文件就头大呀有木有。

 

以下就是解决方法:


  • 在SecurityConfig中添加如下代码
    @Bean
    public UserDetailsService myUserService(){
    	return new MyUserDetailsService();
    }
  • 并且在configure(AuthenticationManagerBuilder auth)方法中将new MyUserService()改为以上的方法名
    @Override
    public void configure(AuthenticationManagerBuilder auth) throws Exception {
        auth.userDetailsService(myUserService());
    }
  • 至此,自定义DetailsService中的Service就可以注入成功了。
  • 另外,自定义DetailsService的@Service标注不需要也没关系,因为已经有@Bean标注了

说一下线索:

  1. Spring Security在Spring加载完Bean之前就加载了(Spring框架中的Web.xml配置相关)
  2. MyUserDetailsService继承AbstractJUnit4SpringContextTests之后输出applicationContext,发现applicationContext为空,说明Spring没有加载完成
  3. Spring没有扫描到MyUserDetailsService,否则@Service肯定能达到与@Bean同样的效果
  4. 这个问题是相当冷门的,所以肯定有一个约定俗成的办法,于是搜一下Spring Security详细搭建就可以找到问题所在了
  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
在 Spring Boot 使用 Spring Security 需要进行以下步骤: 1. 在 pom.xml 文件添加 Spring Security 的依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-security</artifactId> </dependency> ``` 2. 创建一个配置类来配置 Spring Security,例如: ```java @Configuration @EnableWebSecurity public class SecurityConfig extends WebSecurityConfigurerAdapter { @Autowired private UserDetailsService userDetailsService; @Autowired private PasswordEncoder passwordEncoder; @Override protected void configure(HttpSecurity http) throws Exception { http .authorizeRequests() .antMatchers("/login").permitAll() .antMatchers("/admin").hasRole("ADMIN") .anyRequest().authenticated() .and() .formLogin() .loginPage("/login") .defaultSuccessUrl("/home") .permitAll() .and() .logout() .permitAll(); } @Override protected void configure(AuthenticationManagerBuilder auth) throws Exception { auth.userDetailsService(userDetailsService).passwordEncoder(passwordEncoder); } } ``` 3. 创建一个 UserDetailsService 实现类来从数据库或其他存储方式获取用户信息,例如: ```java @Service public class UserDetailsServiceImpl implements UserDetailsService { @Autowired private UserRepository userRepository; @Override public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException { User user = userRepository.findByUsername(username); if (user == null) { throw new UsernameNotFoundException("User not found"); } return new org.springframework.security.core.userdetails.User( user.getUsername(), user.getPassword(), true, true, true, true, AuthorityUtils.createAuthorityList(user.getRoles()) ); } } ``` 4. 创建一个 PasswordEncoder 实现类来对用户密码进行加密,例如: ```java @Configuration public class SecurityConfig { @Bean public PasswordEncoder passwordEncoder() { return new BCryptPasswordEncoder(); } } ``` 这样,你就可以在 Spring Boot 项目使用 Spring Security 了。在这个示例,我们创建了一个基本的 Spring Security 配置类,用于配置访问控制、登录页面、成功登录后的跳转页面等等。然后,我们创建了一个 UserDetailsService 实现类和一个 PasswordEncoder 实现类,用于从数据库获取用户信息并对密码进行加密。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值