将电子邮件发件人bean自动装入另一个bean?

时间:2013-10-18 14:52:25

标签: java spring dependency-injection java-ee-6

我正在使用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" />

的log4j.xml

<?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注释它们是否有任何问题?谢谢!请帮帮我!

1 个答案:

答案 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