3

编辑:我在这里真正要问的是:当配置为使用 JNDI 查找时,如何使用 Logback指定to和电子邮件地址?fromSMTPAppender这应该是功能的基本形式,如果它不支持此功能,就无法使用 JNDI 查找SMTPAppenderSMTPAppender

SMTPAppender定义了以下 Logback:

<appender name="logManager-smtpAppender" class="ch.qos.logback.classic.net.SMTPAppender">
    <filter class="ch.qos.logback.classic.filter.LevelFilter">
        <level>WARN</level>
        <onMatch>ACCEPT</onMatch>
        <onMismatch>NEUTRAL</onMismatch>
    </filter>
    <filter class="ch.qos.logback.classic.filter.LevelFilter">
        <level>ERROR</level>
        <onMatch>ACCEPT</onMatch>
        <onMismatch>DENY</onMismatch>
    </filter>

    <asynchronousSending>false</asynchronousSending>

    <sessionViaJNDI>true</sessionViaJNDI>
    <jndiLocation>java:comp/env/mail/Session-local</jndiLocation>

    <subject>%logger{20} - %m</subject>
    <layout class="ch.qos.logback.classic.html.HTMLLayout"/>
    <cyclicBufferTracker class="ch.qos.logback.core.spi.CyclicBufferTracker">
        <bufferSize>25</bufferSize>
    </cyclicBufferTracker>
</appender>

如您所见,我使用 JNDI 来查找邮件服务器凭据。

当它运行时,我得到:

15:50:06,857 |-ch.qos.logback.classic.net.SMTPAppender[logManager-smtpAppender] 中的信息 - 空目标地址。中止电子邮件传输

这让我意识到:SMTPAppender上面没有任何地方,或者我context.xml没有指定收件人/发件人的电子邮件地址。

我如何/在哪里(请举例!)指定这些?!?我检查了 Logback 的源代码,这条消息是从内部打印出来的SMTPAppenderBase.java

List<InternetAddress> destinationAddresses = parseAddress(lastEventObject);
if (destinationAddresses.isEmpty()) {
    addInfo("Empty destination address. Aborting email transmission");
    return;
}

private List<InternetAddress> parseAddress(E event) {
    int len = toPatternLayoutList.size();

    List<InternetAddress> iaList = new ArrayList<InternetAddress>();

    for (int i = 0; i < len; i++) {
        try {
            PatternLayoutBase<E> emailPL = toPatternLayoutList.get(i);
            String emailAdrr = emailPL.doLayout(event);
            if (emailAdrr == null || emailAdrr.length() == 0) {
                continue;
            }
            InternetAddress[] tmp = InternetAddress.parse(emailAdrr, true);
            iaList.addAll(Arrays.asList(tmp));
        } catch (AddressException e) {
            addError("Could not parse email address for [" +         toPatternLayoutList.get(i) + "] for event [" + event + "]", e);
            return iaList;
        }
    }
    return iaList;
}

但我仍然不知道我应该在哪里/如何设置到/从字段。有任何想法吗?提前致谢!

4

2 回答 2

4

收件人地址和发件人地址与 javamail Session无关。javamail Session 用于配置消息的传输方式,而不是单个消息的详细信息。

您可以使用示例中所示的行在 xml 配置中设置 to 和 from 字段,

<configuration>   
  <appender name="EMAIL" class="ch.qos.logback.classic.net.SMTPAppender">
    <smtpHost>ADDRESS-OF-YOUR-SMTP-HOST</smtpHost>
    <to>EMAIL-DESTINATION</to>
    <to>ANOTHER_EMAIL_DESTINATION</to> <!-- additional destinations are possible -->
    <from>SENDER-EMAIL</from>
    <subject>TESTING: %logger{20} - %m</subject>
    <layout class="ch.qos.logback.classic.PatternLayout">
      <pattern>%date %-5level %logger{35} - %message%n</pattern>
    </layout>       
  </appender>

  <root level="DEBUG">
    <appender-ref ref="EMAIL" />
  </root>  
</configuration>

让 SMTPAppender 使用在 JNDI 连接源中定义的邮件会话凭证

在 jndi 中设置 java 邮件会话凭据是特定于您正在使用的应用程序服务器的。例如,您可以为 tomcat 配置 jndi 凭据,如本问题所示。对于 weblogic,您可以像这样配置它。

于 2013-06-07T02:45:22.403 回答
1

这是一个已知的错误。SMTPAppender 自 1.0.13 起无法使用 JNDI 作为连接源并成功发送电子邮件(它已过早发布)。

于 2013-06-10T12:55:35.520 回答