@Service
public class LogProcessorServiceImpl {
@Autowired
private static ApplicationConfigurationService applicationConfigurationService;
public static void processPageRequestsLogs() {
if(applicationConfigurationService==null) {
System.out.println("autowire failed");
}
我有 ApplicationConfigurationService 服务像这样在整个地方自动连接,它工作正常。正在扫描此类的包,所以这不是问题。它可能与调用此特定方法的方式有关。我有一个在所有其他 servlet 之后加载的 servlet,它会触发一个计时器,该计时器以 60 秒的延迟执行上述方法。我认为应该完成所有自动装配。
public class ProcessSchedulerServlet implements javax.servlet.Servlet {
Timer timer=new Timer();
@Override
public void init(ServletConfig arg0) throws ServletException {
timer.scheduleAtFixedRate(new TimerTask() {
public void run() {
LogProcessorServiceImpl.processPageRequestsLogs();
}
}, 60*1000, 120*1000);
}
这是我真正使用 ApplicationConfigurationService 后会发生的情况:
autowire failed
Exception in thread "Timer-1" java.lang.NullPointerException
at com.siteadmin.services.impl.LogProcessorServiceImpl.processPageRequestsLogs(LogProcessorServiceImpl.java:39)
at com.siteadmin.servlets.ProcessSchedulerServlet$1.run(ProcessSchedulerServlet.java:20)
at java.util.TimerThread.mainLoop(Timer.java:555)
at java.util.TimerThread.run(Timer.java:505)
=== 2012-11-18 ========================================== ===================
另请参阅:如何进行 Spring 自动装配?