zoukankan      html  css  js  c++  java
  • springboot项目中调用第三方jar包中的类时报错 — 没有注入类的2种解决方法

    使用场景:将一些公共的方法封装成了一个jar包,在其他项目中进行引用的时候报错

    报错原因:bean没有注入,引进来的jar包没有被spring管理

    因为这两个类没有被@Service,@Repository等类注解,如果我们想用@Autowired注入会报错

    在项目中注入引用的jar包中的UserService类时报错

    @Autowired
    public UserService userService;

    Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [com.lib.user.UserService] found for dependency: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependency annotations: {@javax.annotation.Resource(shareable=true, lookup=, name=, description=, authenticationType=CONTAINER, type=class java.lang.Object, mappedName=)}

    报错原因:bean没有注入,因为UserService类没有被@Service,@Repository等类注解,所以我们使用@Autowired注入会报错

    解决方法1:可以新建一个UserServiceConfig类,在里面获得我们想要注入的第三方jar包的类,通过@Configuration注解这个Config类,在方法上注解@Bean,这样我们在用@Autowired注解注入就可以了

    @Configuration
    public class UserServiceConfig {
    
        @Bean
        UserService getUserService(){
            UserService  userService = new UserService();
            return userService;
        }
    }

     解决方法2:在主启动类上加入@ComponentScan("/")

    //手动加上@ComponentScan注解并指定那个bean所在的包
    //@ComponentScan 的作用就是根据定义的扫描路径,把符合扫描规则的类装配到spring容器中
    @ComponentScan(basePackages={"com.util.user"}) public class UserApplication { public static void main(String[] args) { SpringApplication.run(UserApplication .class, args); } }
  • 相关阅读:
    批量导出数据库表(oracle)
    Neo4j安装配置(mac)
    项目实施计划方案
    分布式数据库笔记
    SQL优化——ORACLE
    INNER JOIN & OUTER JOIN
    sqlMap.xml配置文件中迭代一个集合的方式
    sql下的xml配置文件中特殊使用的sql语句编写
    将查询列表内容保存到excel表格中,并保存到相应的盘中
    Spring框架中AOP特性
  • 原文地址:https://www.cnblogs.com/wueryuan/p/12884366.html
Copyright © 2011-2022 走看看