关于springboot项目中自动注入,但是用的时候值为空的BUG

最近想做一些web项目来填充下业余时间,首先想到了使用springboot框架,毕竟方便 快捷

首先:去这里 http://start.spring.io/ 直接构建了一个springboot初始化的项目框架

然后:在页面上选择相应的依赖包,然后点击构建按钮,然后下载并且导入IDE中,目前喜欢使用IDEA

于是一个简答的springboot项目就搭建好了

废话说完,然后想体验下spring中redis的使用;

那就直接新建了一个类,然后 @Autowired 自动注入 RedisTemplate 类,当然在这个类上面是要加上 @Component 注解的。

但是问题来了,在这个类下面创建了一个方法,然后方法里面调用redisTemplate的时候,提示为null,这是为什么呢?

下面是尝试了各种网上分享的解决方案中认为比较有用的几种方式:

  1.注解没有扫描到,问题原因可能是springboot启动类没有放到最外层的包的根目录下面

因为springboot启动的时候会自动扫描启动类所在包的所有子包里面包含的注解,如果启动类放错了位置,会导致注解扫描不到

具体逻辑,请看

@SpringBootApplication 注解中包含的 @ComponentScan 这个注解的解析,就是扫描注解的一些逻辑

  2.调用的时候,使用的对象是被new出来的,而不是spring自动注入进来的,没有被spring来管理,所以当然为null

比如:在类 A里面 注入了 redisTemplate  然后,springboot项目启动之后在A类里面又创建了一个 main方法,然后在main里面,new A(); 来创建一个A的实例,然后再A.redisTemplate 进行调用,获取到的就是一个NULL值

故:解决方式就是 如果想要使用 @Autowired注入一些springboot自动管理的工具的话,比如 redisTemplate  /  jdbcTemplate  等等,要么就是直接在启动类里面进行注入,不过这样用的比较少,一般都会新建一个类,然后在里面进行注入,

但是如果想要使用的话需要继承这个类,然后再子类中进行使用,比如使用redisTemplate  和  jdbcTemplate 的话,就可以创建一个 DataSourceConfig 类,然后自动注入  redisTemplate  和  jdbcTemplate 然后新建两个方法, getRedisTemplate()  和 getJdbcTemplate()

里面对应的返回相应的 template ,然后在 dao 中使用的时候就可以直接继承 DataSourceConfig  ,然后直接使用  getRedisTemplate()    和 getJdbcTemplate()  这两个方法,来获取到redis 和jdbcTemplate 进行数据的操作

以上仅为本人最近遇到的一个比较无语的bug解决之后的备忘,以后勿犯

但是如果刚接触springboot的话,可能会遇到此类问题,欢迎一起探讨

如有帮助到后来人,则功德无量

时间: 2024-10-05 05:02:07

关于springboot项目中自动注入,但是用的时候值为空的BUG的相关文章

解决Springboot项目中jpa扫描不到实体的问题

在一些情况下Springboot项目中jpa扫描不到实体.比如默认扫描不到引用的其他项目中定义的实体.导致无法自动创建表. 解决方法,在Application中自定义实体扫描的包 @EntityScan(basePackages = {"com.aaa"}) @SpringBootApplication @EnableDiscoveryClient @ComponentScan(basePackages = {"com.aaa.*"}) @EntityScan(ba

springBoot项目中的static和templates文件夹

记录是为了更好的成长! 1.static文件中的页面 //这样写不能访问static中index文件夹下的index.html页面 @RequestMapping("index") public String hello() { return "/index/index"; } //这样写才能访问到 @RequestMapping("index") public String hello() { return "/index/index

在SpringBoot项目中添加logback的MDC

在SpringBoot项目中添加logback的MDC 先看下MDC是什么 Mapped Diagnostic Context,用于打LOG时跟踪一个“会话“.一个”事务“.举例,有一个web controller,在同一时间可能收到来自多个客户端的请求,如果一个请求发生了错误,我们要跟踪这个请求从controller开始一步步都执行到了哪些代码.有哪些log的输出.这时我们可以看log文件,但是log文件是多个请求同时记录的,基本无法分辨哪行是哪个请求产生的,虽然我们可以看线程,但线程可能被复

springboot项目中配置self4j

首先,声明一下,springboot项目中默认情况下已经集成了self4J + LogBack. slf4j作为一个接口定义,底层可以有很多实现框架,同时也可以支持别的日志实现或者框架打到sfl4j上.它的实现是基于不同的桥接包.slf4j作为接口定义,下面有很多种实现.实现原理是获取ILoggerFactory时执行初始化,初始化过程绑定实现对象:load出所有实现StaticLoggerBinder的类,然后获取他的单例,后面执行getLogger的时候都是调用这个单例类的方法获取对应有具体

SpringBoot 项目中使用Log4j2

Log4j 系列 log4j是apache实现的一个开源日志组件 logback同样是由log4j的作者设计完成的,拥有更好的特性,用来取代log4j的一个日志框架,是slf4j的原生实现 log4j2是log4j 1.x和logback的改进版,据说采用了一些新技术(无锁异步.等等),使得日志的吞吐量.性能比log4j 1.x提高10倍,并解决了一些死锁的bug,而且配置更加简单灵活 slf4j是对所有日志框架制定的一种规范.标准.接口,并不是一个框架的具体的实现,因为接口并不能独立使用,需要

Java实战之路(1):SpringBoot项目中使用Mybatis打印Sql语句

SpringBoot项目中使用Mybatis打印Sql语句 如题,实际项目中使用很多都会用到SpringBoot+Mybatis的经典搭配进行开发,数据库里明明有数据,可是程序运行就是查不到,此时我们在本地Debug时,需要将Mybatis的实际Sql打印出来,看看Sql与我们期望的是否一致,或者将Sql拿到数据库中直接执行,看看结果.这里简单介绍几种实战中的用法. 方法一 properties:在application.properties配置文件中增加如下配置 logging.level.c

【MARK】拦截器中自动注入失败问题

我在拦截器中想自动注入一个对象的时候发现无法注入,获取到的一直是null public class RestInterceptor implements HandlerInterceptor { @Autowired private EscUserMapper escUserMapper; @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object hand

带你开发一款给Apk中自动注入代码工具icodetools(开凿篇)

一.前言 从这篇开始咋们开始一个全新的静态方式逆向工具icodetools的实现过程,这个也是我自己第一次写的个人觉得比较有用的小工具,特别是在静态方式逆向apk找关键点的时候,后续会分为三篇来详细介绍这个工具实现: 第一篇:开凿篇,简单介绍实现原理以及简单的初次方案实现简单的apk注入代码功能 第二篇:填坑篇,这一篇是在前一篇的基础上对工具的优化,可以应对市面上大部分的apk代码注入功能实现 第三篇:生产篇,这一篇是在前两篇的基础上利用这个工具来实际操刀如何进行快速定位应用的关键方法功能 还记

springboot项目中,@transactional 无效

问题: springboot项目,依然是使用jpa.Hibernate来操作mysql,涉及到数据库的操作,就少不了事务.写了一个接口,用来测试@Transaction注解的作用,发现没有效果 分析: 在项目启动时候,看到Hibernate: create table hibernate_sequence (next_val bigint) engine=MyISAM,说明是MyISAM引擎,由此我们也就很容易想到MyISAM与InnoDB之间的区别 解决: 发现Hibernate默认创建的表是