70. 打印所有Spring boot载入的bean

 

【视频 & 交流平台】

à SpringBoot视频

http://study.163.com/course/introduction.htm?courseId=1004329008&utm_campaign=commission&utm_source=400000000155061&utm_medium=share

à SpringCloud视频

http://study.163.com/course/introduction.htm?courseId=1004638001&utm_campaign=commission&utm_source=400000000155061&utm_medium=share

à Spring Boot源码

https://gitee.com/happyangellxq520/spring-boot

à Spring Boot交流平台

http://412887952-qq-com.iteye.com/blog/2321532

 


 

 


【从零开始学习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[] beanNamesctx.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[] beanNamesctx.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[] beanNamesctx.getBeanNamesForAnnotation(Repository.class);

       System.out.println("Repository注解beanNames个数:"+beanNames.length);

       for(Stringbn:beanNames){

           System.out.println(bn);

       }

       控制台打印如下:

Repository注解beanNames个数:4

demoInfo3Dao

demoInfoDao

demoInfoForBaseJpaObjDao

demoInfo1DaoImpl

悟纤 CSDN认证博客专家 知远公司创始人 架构师 访问1000万+
「公众号SpringBoot」:
①阿里巴巴前高级研发工程师;
②估值20亿美金的Blued架构师;
③北京知远公司创始人;
④浙江甄才公司架构师;
⑤云课堂学员10000+;
⑥博客访问量1000万+;
⑦10年互联网行业从业;
⑧360万的访问《从零开始学SprngBoot》作者;
⑨技术加盟多个独立项目。
相关推荐
©️2020 CSDN 皮肤主题: 酷酷鲨 设计师:CSDN官方博客 返回首页
实付 19.89元
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值