我有一个使用服务的记录器类。每次创建新记录器时,我都希望能够访问单例范围的日志记录服务。
我将日志记录服务自动连接到记录器中,但是返回了一个空指针异常。我尝试了一些解决方案:
- 在应用程序上下文中手动定义 bean,
- 试图让记录器由 spring 管理,但这只会导致更多问题。
我试图让它在我的 junit 测试中工作,并且我确实指定了上下文文件以使用不同的应用程序上下文。然而,即使保持相同也不能解决问题。
请在下面找到代码:
以下是应用上下文的摘录。
<context:component-scan base-package="com.platform"/>
<bean id="asyncLoggingService" class="com.platform.services.AsyncLoggingServiceImplementation" scope="prototype"/>
下面是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 服务器)在服务中,我实例化了一个新的记录器实例,然后相应地使用它。
@Service
public class AsyncAccountServiceImplementation implements AsyncAccountService
{
private static final String GATEWAY_IP_BLOCK = "1";
private static OurLogger logger = new OurLogger(AsyncAccountServiceImplementation.class);
...
}
当我尝试调用 asyncLoggingService
上的任何方法时,空指针出现在 OurLogger
中。
然后我尝试使用 JUnit 测试 AsyncAccountService
。我确保我添加了不同的应用程序上下文,但它似乎仍然导致空指针异常。
如果您需要更多信息,请告诉我。我已经找到解决此问题的方法,但它们似乎不起作用,所以也许我在某处犯了错误,或者我没有完全正确地理解这一切。
最佳答案
当您通过 new 创建对象时,autowire\inject 不起作用...
无论如何,如果你想注入(inject)一个记录器,我建议你 this我对另一个话题的回答。
关于java - Spring Autowiring 的bean导致空指针,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25991191/