暂时留个坑: 因为“application类”的包名与service的包名不同,导致service下的类无法自动注入。
解决方案:
1 使用@ComponentScan 注解,如下文转载的文章,但是我自己改了还是有问题,暂时没找到原因,待补充;
2 将“Application类”与service放到同一个包下 -->可以正常运行
【转自】http://blog.csdn.net/u014695188/article/details/52263903
[html] view plain copy 
org.sPRingframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'com.example.SpringBootJdbcDemoApplication.SpringBootJdbcDemoApplication': Unsatisfied dependency expressed through field 'userRepository': No qualifying bean of type [com.example.repositories.UserRepository] found for dependency [com.example.repositories.UserRepository]: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)}; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [com.example.repositories.UserRepository] found for dependency [com.example.repositories.UserRepository]: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)} at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:569) at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:88) 无法注入Dao中的Bean!
解决分析后来经研究发现,SpringBoot项目的Bean装配默认规则是根据Application类所在的包位置从上往下扫描! “Application类”是指SpringBoot项目入口类。这个类的位置很关键:
如果Application类所在的包为:io.github.gefangshuai.app
,则只会扫描io.github.gefangshuai.app
包及其所有子包,如果service或dao所在包不在io.github.gefangshuai.app
及其子包下,则不会被扫描!
知道这一点非常关键,不知道spring文档里有没有给出说明,如果不知道还真是无从解决。
转:http://blog.csdn.NET/gefangshuai/article/details/50328451,http://412887952-QQ-com.iteye.com/blog/2292733
在开发中我们知道Spring%20Boot默认会扫描启动类同包以及子包下的注解,那么如何进行改变这种扫描包的方式呢,原理很简单就是:@ComponentScan注解进行指定要扫描的包以及要扫描的类。接下来我们简单写个例子进行测试下。
第一步:新建两个新包 %20我们在项目中新建两个包cn.kfit%20;%20org.kfit;
第二步:新建两个测试类;在这里为了方便测试,我们让我们的类在启动的时候就进行执行,所以我们就编写两个类,实现接口CommandLineRunner,这样在启动的时候我们就可以看到打印信息了。cn.kfit.MyCommandLineRunner1 %20:
[html] view%20plain copy ![在CODE上查看代码片]()
package cn.kfit; import org.springframework.boot.CommandLineRunner; @Configuration publicclass MyCommandLineRunner1 implements CommandLineRunner { @Override publicvoid run(String... args) throws Exception { System.out.println("MyCommandLineRunner1.run()"); } } org.kfit.MyCommandLineRunner2 %20: [html] view%20plain copy ![在CODE上查看代码片]()
package org.kfit; import org.springframework.boot.CommandLineRunner; @Configuration publicclass MyCommandLineRunner2 implements CommandLineRunner { @Override publicvoid run(String... args) throws Exception { System.out.println("MyCommandLineRunner2.run()"); } } 第三步:启动类进行注解指定在App.java类中加入如下注解:[html] view%20plain copy ![在CODE上查看代码片]()
//可以使用:basePackageClasses={},basePackages={} @ComponentScan(basePackages={"cn.kfit","org.kfit"}) 启动如果看到打印信息:[html] view%20plain copy ![在CODE上查看代码片]()
MyCommandLineRunner1.run() MyCommandLineRunner2.run() 说明我们配置成功了。这时候你会发现,在App.java同包下的都没有被扫描了,所以如果也希望App.java包下的也同时被扫描的话,那么在进行指定包扫描的时候一定要进行指定配置:[html] view%20plain copy ![在CODE上查看代码片]()
@ComponentScan(basePackages={"cn.kfit","org.kfit","com.kfit"})