70. 打印所有Spring boot载入的bean
2017-01-03 15:50
155 查看
【从零开始学习SpirngBoot—常见异常汇总】
问题的提出:
我们在开发过程当中,我们可能会碰到这样的问题:No qualifying bean 就是我们定义的bean无法进行注入,那到底是什么原因呢,有时候挺难定位的,当然这个也需要养成良好的编码习惯,这样也会降低出错的几率。那么一般说是No
quanlifying bean很有可能就是我们没有使用注解或者xml注入我们的bean,要么就是我们bean的名称不是我们注入时指定的名称,那么我们就会想如何查看已经载入到spring boot的bean呢?
其实这个操作起来很简单,看如下介绍知道了。
Spring main方法启动
我们以前写代码在main方法的启动类基本上就一行代码,看如下:
SpringApplication.run(ApiCoreApp.class,args);
我们只需要稍微调整下就可以获取到ApplicationContext上下文了,在这个类中就可以有很多的方法进行操作了,修改为如下:
ApplicationContext
ctx = SpringApplication.run(ApiCoreApp.class,args);
有了ctx那么接下来就很简单了:
第一种情况获取所有的beans:
ApplicationContext
ctx = SpringApplication.run(ApiCoreApp.class,args);
String[]
beanNames = ctx.getBeanDefinitionNames();
System.out.println("所以beanNames个数:"+beanNames.length);
for(Stringbn:beanNames){
System.out.println(bn);
}
观察控制台打印(这里只截取部分信息):
所有beanNames个数:177
org.springframework.context.annotation.internalPersistenceAnnotationProcessor
org.springframework.context.event.internalEventListenerProcessor
org.springframework.context.event.internalEventListenerFactory
apiCoreApp
org.springframework.context.annotation.ConfigurationClassPostProcessor.importAwareProcessor
org.springframework.context.annotation.ConfigurationClassPostProcessor.enhancedConfigurationProcessor
demoInfo3Dao
demoInfoDao
demoInfoForBaseJpaObjDao
demoInfo1DaoImpl
我们会看到控制台打印了好多的自带的对象,那么怎么查看我们自己编写的呢?看如下代码:
第二种情况获取我们指定的注解类:
@service注解代码:
ApplicationContext
ctx = SpringApplication.run(ApiCoreApp.class,args);
String[]
beanNames = ctx.getBeanNamesForAnnotation(Service.class);
System.out.println("Service注解beanNames个数:"+beanNames.length);
for(Stringbn:beanNames){
System.out.println(bn);
}
查看控制台打印:
service注解beanNames个数:3
demoInfo1Service
demoInfo2Service
demoInfoService
是不是瞬间干净了很多。
@Repository注解代码:
ApplicationContext
ctx = SpringApplication.run(ApiCoreApp.class,args);
String[]
beanNames = ctx.getBeanNamesForAnnotation(Repository.class);
System.out.println("Repository注解beanNames个数:"+beanNames.length);
for(Stringbn:beanNames){
System.out.println(bn);
}
控制台打印如下:
Repository注解beanNames个数:4
demoInfo3Dao
demoInfoDao
demoInfoForBaseJpaObjDao
demoInfo1DaoImpl
问题的提出:
我们在开发过程当中,我们可能会碰到这样的问题:No qualifying bean 就是我们定义的bean无法进行注入,那到底是什么原因呢,有时候挺难定位的,当然这个也需要养成良好的编码习惯,这样也会降低出错的几率。那么一般说是No
quanlifying bean很有可能就是我们没有使用注解或者xml注入我们的bean,要么就是我们bean的名称不是我们注入时指定的名称,那么我们就会想如何查看已经载入到spring boot的bean呢?
其实这个操作起来很简单,看如下介绍知道了。
Spring main方法启动
我们以前写代码在main方法的启动类基本上就一行代码,看如下:
SpringApplication.run(ApiCoreApp.class,args);
我们只需要稍微调整下就可以获取到ApplicationContext上下文了,在这个类中就可以有很多的方法进行操作了,修改为如下:
ApplicationContext
ctx = SpringApplication.run(ApiCoreApp.class,args);
有了ctx那么接下来就很简单了:
第一种情况获取所有的beans:
ApplicationContext
ctx = SpringApplication.run(ApiCoreApp.class,args);
String[]
beanNames = ctx.getBeanDefinitionNames();
System.out.println("所以beanNames个数:"+beanNames.length);
for(Stringbn:beanNames){
System.out.println(bn);
}
观察控制台打印(这里只截取部分信息):
所有beanNames个数:177
org.springframework.context.annotation.internalPersistenceAnnotationProcessor
org.springframework.context.event.internalEventListenerProcessor
org.springframework.context.event.internalEventListenerFactory
apiCoreApp
org.springframework.context.annotation.ConfigurationClassPostProcessor.importAwareProcessor
org.springframework.context.annotation.ConfigurationClassPostProcessor.enhancedConfigurationProcessor
demoInfo3Dao
demoInfoDao
demoInfoForBaseJpaObjDao
demoInfo1DaoImpl
我们会看到控制台打印了好多的自带的对象,那么怎么查看我们自己编写的呢?看如下代码:
第二种情况获取我们指定的注解类:
@service注解代码:
ApplicationContext
ctx = SpringApplication.run(ApiCoreApp.class,args);
String[]
beanNames = ctx.getBeanNamesForAnnotation(Service.class);
System.out.println("Service注解beanNames个数:"+beanNames.length);
for(Stringbn:beanNames){
System.out.println(bn);
}
查看控制台打印:
service注解beanNames个数:3
demoInfo1Service
demoInfo2Service
demoInfoService
是不是瞬间干净了很多。
@Repository注解代码:
ApplicationContext
ctx = SpringApplication.run(ApiCoreApp.class,args);
String[]
beanNames = ctx.getBeanNamesForAnnotation(Repository.class);
System.out.println("Repository注解beanNames个数:"+beanNames.length);
for(Stringbn:beanNames){
System.out.println(bn);
}
控制台打印如下:
Repository注解beanNames个数:4
demoInfo3Dao
demoInfoDao
demoInfoForBaseJpaObjDao
demoInfo1DaoImpl
相关文章推荐
- 70. 打印所有Spring boot载入的bean
- 70.打印所有Spring boot载入的bean【从零开始学Spring Boot】
- 在web应用中获取spring的context,并打印出context中所有bean的id
- springboot打印扫描到的的bean
- spring boot如何在所有bean初始化之前加载一个自定义类?
- Spring Boot - 获取所有的Bean信息
- Spring Boot 使用Java代码创建Bean并注册到Spring中
- spring 所有bean 加载顺序
- 通过ApplicationContextAware接口获取Spring配置文件中的所有Bean
- spring源码学习之路---IOC容器初始化要义之bean定义载入
- spring boot获取注入的实例bean
- Spring ProxyFactoryBean 是如何实现所有的AOP proxy都有可能转为Advised接口的?
- spring源码学习之路---IOC容器初始化要义之bean定义载入(五)
- spring boot conditionBean MissingBean @configuration 配置不存在问题
- Spring boot Bean 的Scope
- SpringBoot动态创建Bean
- spring boot的Bean,Controller以及Repository的创建
- Spring源码学习IOC(3):IoC容器载入Bean定义资源文件
- spring—容器启动载入bean过程
- spring 源码解读与设计详解:4 DefaultListableBeanFactory及资源载入