70.打印所有Spring boot载入的bean【从零开始学Spring Boot】
【从零开始学习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[] beanNames = ctx.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[] beanNames = ctx.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[] beanNames = ctx.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
61. mybatic insert异常:BindingException: Parameter 'name' not found【从零开始学Spring B】
60. Spring Boot写后感【从零开始学Spring Boot】
59. Spring Boot Validator校验【从零开始学Spring Boot】
58. Spring Boot国际化(i18n)【从零开始学Spring Boot】
57. Spring 自定义properties升级篇【从零开始学Spring Boot】
56. spring boot中使用@Async实现异步调用【从零开始学Spring Boot】
55. spring boot 服务配置和部署【从零开始学Spring Boot】
54. spring boot日志升级篇—logback【从零开始学Spring Boot】
52. spring boot日志升级篇—log4j多环境不同日志级别的控制【从零开始学Spring Boot】
51. spring boot属性文件之多环境配置【从零开始学Spring Boot】
50. Spring Boot日志升级篇—log4j【从零开始学Spring Boot】
49. spring boot日志升级篇—理论【从零开始学Spring Boot】
48. spring boot单元测试restfull API【从零开始学Spring Boot】
47. Spring Boot发送邮件【从零开始学Spring Boot】
46. Spring Boot中使用AOP统一处理Web请求日志
45. Spring Boot MyBatis连接Mysql数据库【从零开始学Spring Boot】
44. Spring Boot日志记录SLF4J【从零开始学Spring Boot】
43. Spring Boot动态数据源(多数据源自动切换)【从零开始学Spring Boot】
42. Spring Boot多数据源【从零开始学Spring Boot】
41. Spring Boot 使用Java代码创建Bean并注册到Spring中【从零开始学Spring Boot】
40. springboot + devtools(热部署)【从零开始学Spring Boot】
39.4 Spring Boot Shiro权限管理【从零开始学Spring Boot】
39.3 Spring Boot Shiro权限管理【从零开始学Spring Boot】
39.2. Spring Boot Shiro权限管理【从零开始学Spring Boot】
39.1 Spring Boot Shiro权限管理【从零开始学Spring Boot】
38 Spring Boot分布式Session状态保存Redis【从零开始学Spring Boot】
37 Spring Boot集成EHCache实现缓存机制【从零开始学Spring Boot】
36 Spring Boot Cache理论篇【从零开始学Spring Boot】
35 Spring Boot集成Redis实现缓存机制【从零开始学Spring Boot】
34Spring Boot的启动器Starter详解【从零开始学Spring Boot】
33 Spring Boot 监控和管理生产环境【从零开始学Spring Boot】
32 Spring Boot使用@SpringBootApplication注解【从零开始学Spring Boot】