【Bug记录】调用Controller中的方法的Service为null

原文链接:【Bug 记录】调用 Controller 中的方法的 Service 为 null

问题

今天写代码的时候遇到了一个奇怪的Bug,在Controller中调用某个方法时突然报空指针异常,打断点时发现service为null,并尝试了数种注入方式,发现均为null。

原因分析

首先去检查了一下Service上的注解,发现是有 @Service 注解的,因为使用了Lombok的 @RequiredArgsConstructor 注解1,所以在想是不是Lombok的原因,后面去掉该注解,分别尝试了使用 @Autowired 注入、@Resource 注入以及构造器注入,调用时发现仍为null。

上网查询资料后发现关注点错了,既然Service添加了对应注解,且也尝试了不同的注入方法,如果其他方法也均是使用这种方式注入且没出问题的,那就说明问题出在方法上。

在检查方法时发现,在Controller层,方法定义时使用了private 修饰,而不是正常的 public,如下:

查阅资料后发现:容器在扫描Bean并生成代理类的时候,只会生成被 publicprotected 修饰的方法的代理类,被 private 修饰的方法并不会生成代理类。

Q: 那为什么我们的类是使用 public 方法修饰的,此处使用 private 修饰方法就无法获取到Bean了呢?
A: 因为属性的注入也是在代理类中完成的,被 publicprotected 修饰的方法获取到的属性也是已经完成注入的属性,而 private 修饰的方法获取的是还未完成注入的属性,因此获取Bean时为null。


  1. @RequiredArgsConstructor注解:加了该注解的类会在代码编译时,自动给该类加上一个构造器注入,无需使用 @Autowired 或 @Resource 注解,其生效条件为必须由 final 所修饰。 ↩︎

相关推荐

  1. 在 MyBatis-Plus ,字段更新 null 方法

    2024-05-01 05:44:02       20 阅读
  2. 如何在非spring环境调用service方法

    2024-05-01 05:44:02       44 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-01 05:44:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-01 05:44:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-05-01 05:44:02       82 阅读
  4. Python语言-面向对象

    2024-05-01 05:44:02       91 阅读

热门阅读

  1. 安信天行-渗透测试实习生

    2024-05-01 05:44:02       30 阅读
  2. make构建自动化工具介绍

    2024-05-01 05:44:02       22 阅读
  3. redis工具类

    2024-05-01 05:44:02       21 阅读
  4. python-基础(7)-判断结构

    2024-05-01 05:44:02       33 阅读
  5. QT学习之QFileDialog

    2024-05-01 05:44:02       31 阅读
  6. FlaUI

    FlaUI

    2024-05-01 05:44:02      33 阅读
  7. Axios 库相关

    2024-05-01 05:44:02       33 阅读