博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
70.打印所有Spring boot载入的bean【从零开始学Spring Boot】
阅读量:6984 次
发布时间:2019-06-27

本文共 2169 字,大约阅读时间需要 7 分钟。

【从零开始学习Spirng Boot—常见异常汇总】

问题的提出:

       我们在开发过程当中,我们可能会碰到这样的问题: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(String bn: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(String bn: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(String bn:beanNames){

           System.out.println(bn);

       }

       控制台打印如下:

Repository注解beanNames个数:4

demoInfo3Dao

demoInfoDao

demoInfoForBaseJpaObjDao

 

demoInfo1DaoImpl

 

【Spring Boot 系列博客】

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

更多查看博客: 

转载于:https://www.cnblogs.com/hehehaha/p/6147068.html

你可能感兴趣的文章
Java-集合的简单介绍
查看>>
分布式架构发展
查看>>
针对不同的系统的宏定义
查看>>
Spring Boot + Vue 前后端分离,两种文件上传方式总结
查看>>
第一次搭建阿里云服务器
查看>>
java 文件存储
查看>>
Android build.gradle 获取Git 仓库数据
查看>>
十分钟熟练Dockerfile指令
查看>>
ES6新特征总结与介绍——声明与表达式
查看>>
python3实现抓取网页资源的 N 种方法(内附200GPython学习资料)
查看>>
自定义网络请求框架
查看>>
Unity(射线)
查看>>
阿里云媒体转码MTS使用教程
查看>>
shell常见的文件属性检查
查看>>
年度最期待游戏废土2登陆Linux
查看>>
CA knowledge study
查看>>
linux目录结构简析
查看>>
VMware ESXi部署OVF模板
查看>>
2上的svn部署
查看>>
《***测试实践指南》D03
查看>>