rob*_*ien 7 java junit spring autowired spring-annotations
我有一个使用服务的记录器类.每次创建新的记录器时,我都希望能够访问单例范围的日志记录服务.
我将日志记录服务自动装入logger,但是返回了一个空指针异常.我尝试了一些解决方案:
我试图在junit测试中使用它,并且我确实指定了上下文文件以使用不同的应用程序上下文.但即使保持相同,也无法解决问题.
请在下面找到代码:
以下是应用程序上下文的摘录.
<context:component-scan base-package="com.platform"/>
<bean id="asyncLoggingService" class="com.platform.services.AsyncLoggingServiceImplementation" scope="prototype"/>
Run Code Online (Sandbox Code Playgroud)
以下是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
}
Run Code Online (Sandbox Code Playgroud)
}
然后我在另一个服务中使用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);
...
}
Run Code Online (Sandbox Code Playgroud)
OurLogger当我尝试调用任何方法时,出现空指针asyncLoggingService.
然后我试图测试AsyncAccountService使用JUnit.我确保添加不同的应用程序上下文,但它似乎仍然导致空指针异常.
如果您需要更多信息,请告诉我.我已经看到了解决这个问题的方法,但它们似乎没有用,所以也许我在某个地方犯了错误,或者我并没有完全理解这一点.
| 归档时间: |
|
| 查看次数: |
34574 次 |
| 最近记录: |