Spring autowired bean导致空指针

 撒谎滴土豆 发布于 2022-12-20 10:20

我有一个使用服务的记录器类.每次创建新的记录器时,我都希望能够访问单例范围的日志记录服务.

我将日志记录服务自动装入logger,但是返回了一个空指针异常.我尝试了一些解决方案:

    在应用程序上下文中手动定义bean,

    试图让记录器进行弹簧管理,但这只会导致更多问题.

我试图在junit测试中使用它,并且我确实指定了上下文文件以使用不同的应用程序上下文.但即使保持相同,也无法解决问题.

请在下面找到代码:

以下是应用程序上下文的摘录.



以下是Logger类.

package com.platform.utils;


import com.platform.services.AsyncLoggingService;
import org.joda.time.DateTime;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;

public class OurLogger
{

  private static Logger logger;

  @Autowired
  private AsyncLoggingervice asyncLoggingService;

  public OurLogger(Class Clazz)
  {
    logger = LoggerFactory.getLogger(Clazz);
  }


  public void trace(TraceableObject object, String message)
  { 
    //Do nothing yet
  }

}

然后我在另一个服务中使用Logger来记录最新情况.(我写另一个记录器的原因是使用RabbitMQ服务器)在服务中我实例化Logger的一个新实例,然后相应地使用它.

@Service
public class AsyncAccountServiceImplementation implements AsyncAccountService
{
  private static final String GATEWAY_IP_BLOCK = "1";

  private static OurLogger logger = new      OurLogger(AsyncAccountServiceImplementation.class);

...
}

OurLogger当我尝试调用任何方法时,出现空指针asyncLoggingService.

然后我试图测试AsyncAccountService使用JUnit.我确保添加不同的应用程序上下文,但它似乎仍然导致空指针异常.

如果您需要更多信息,请告诉我.我已经看到了解决这个问题的方法,但它们似乎没有用,所以也许我在某个地方犯了错误,或者我并没有完全理解这一点.

1 个回答
  • 当你用new创建一个对象时,autowire\inject不起作用......

    有关解决方法,请参阅此链接和此链接.

    无论如何,如果你注入一个记录器,我建议你这是我对另一个主题的回答.

    2022-12-20 10:24 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有