我正在使用spring 3.x版本,并使用注释来连接依赖项。我有两个豆子如下。
package com.sample.project.service;
@Component
public class MyAppender extends AppenderSkeleton{
//here trying to inject emailSender bean
@Autowired
private EmailSender emailSender;
//some code with emailSender
//emailSender.callSomeService...
}
上面的bean扩展了log4j的AppenderSkeleton类。
package com.sample.project.service;
@Component
public class EmailSender {
@Autowired
private SomeOtherBean someOther;
//somecode
}
我在applicationContext.xml中有一个条目,如下所示。
<context:component-scan base-package="com.sample.project.service" />
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="false">
<!-- Appenders -->
<appender name="stdout" class="com.sample.project.service.MyAppender">
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d %p [%c] - %m%n"/>
</layout>
</appender>
<appender name="ASYNC" class="org.apache.log4j.AsyncAppender">
<param name="BufferSize" value="500"/>
<appender-ref ref="stdout"/>
</appender>
<root>
<level value="INFO" />
<appender-ref ref="ASYNC" />
</root>
</log4j:configuration>
但问题是emailSender
注入MyAppender
始终是null
。
我在这里做错了什么。或者覆盖log4j
个特定类并使用@Component
注释它们是否有任何问题?谢谢!请帮帮我!
答案 0 :(得分:0)
使用此配置
<appender name="stdout" class="com.sample.project.service.MyAppender">
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d %p [%c] - %m%n"/>
</layout>
</appender>
log4j正在创建自己的MyAppender
实例。此实例与Spring创建的@Component
实例无关。因此,没有自动装配,默认情况下您的字段初始化为null
。