如果您阅读过本系列以前的任何博客,您可能会记得我正在开发一个小型但几乎具有工业实力的应用程序,该应用程序在日志文件中搜索异常。 您可能还记得,我现在有一个可以包含一堆结果的类,需要将其发送给感兴趣的任何人。 这将通过实现下面显示的简单Publisher界面来完成。

public interface Publisher { 

  public <T> boolean publish(T report); 
}

如果您还记得,那么要求是:

7 . Publish the report using email or some other technique.

在此博客中,我要处理需求的具体部分:通过电子邮件发送报告。 由于这是Spring应用程序,因此发送电子邮件的最简单方法是使用Spring的电子邮件类。 与Spring API的坚强后盾(模板类,例如JdbcTemplate和JmsTemplate)不同,Spring电子邮件类基于两个接口及其实现。 这些接口是:

  1. 邮件发件人
  2. JavaMailSender扩展MailSender
  3. 邮件留言

……实现是:

  1. JavaMailSenderImpl实现JavaMailSender
  2. SimpleMailMessage实现MailMessage

请注意,这些是“基本”类; 您可以使用诸如MimeMailMessage,MimeMailMessageHelper,ConfigurableMimeFileTypeMap和MimeMessagePreparator之类的类发送美观,更复杂的电子邮件内容。

在编写一些代码之前,几乎没有什么项目配置问题。 要使用Spring电子邮件类,您需要在Maven POM文件中输入以下内容:

<dependency>
    <groupId>javax.mail</groupId>
    <artifactId>mail</artifactId>
    <version>1.4</version>
</dependency>

这样可以确保基础Java Mail类可用于您的应用程序。

一旦在构建中配置了Java Mail类,接下来要做的就是设置Spring XML配置。

<!-- Spring mail configuration -->

     <bean id="mailSender" class="org.springframework.mail.javamail.JavaMailSenderImpl">
          <property name="host" value="${mail.smtp.host}"/>
     </bean>

     <!-- this is a template message that we can pre-load with default state -->
     <bean id="mailMessage" class="org.springframework.mail.SimpleMailMessage">
          <property name="to" value="${mail.to}"></property>
            <property name="from" value="${mail.from}"/>
            <property name="subject" value="${mail.subject}"/>
     </bean>

对于这个应用程序,这是发出自动报告的目的,我已经包括了两个弹簧豆: mailSendermailMessagemailSender是一个JavaMailSenderImpl实例,配置为使用特定的SMTP邮件服务器,并将所有其他属性(例如TCP端口)保留为默认值。

第二个春天bean是mailMessage ,实例SimpleMailMessage 。 这次,我已经预配置了三个属性:“至”,“来自”和“主题”。 这是因为,作为自动消息,这些值始终相同。

当然,您可以以编程方式配置这些,如果您要创建邮件GUI,则可能需要做一些事情。

所有这些XML使得Publisher的实现非常简单。

@Service 
public class EmailPublisher implements Publisher { 

  private static final Logger logger = LoggerFactory.getLogger(EmailPublisher.class); 

  @Autowired 
  private MailSender mailSender; 

  @Autowired 
  private SimpleMailMessage mailMessage; 

  @Override 
  public <T> boolean publish(T report) { 

    logger.debug("Sending report by email..."); 
    boolean retVal = false; 
    try { 
      String message = (String) report; 
      mailMessage.setText(message); 
      mailSender.send(mailMessage); 
      retVal = true; 
    } catch (Exception e) { 
      logger.error("Can't send email... " + e.getMessage(), e); 
    } 

    return retVal; 
  } 

}

Publisher类包含一个方法: publish ,它采用通用参数T report 。 正如我之前所说,此类型必须与我以前的博客中Formatter实现返回的参数类型相同。

此代码中实际上只需要考虑三个步骤:首先,将泛型T强制转换为String (如果参数T report不是String ,这将全部转换为String

第二步是将电子邮件的正文附加到mailMessage ,然后发送使用消息mailSender.send(…)

最后一步是通过返回true来履行Publisher合同,除非电子邮件发送失败,在这种情况下,将记录异常并且返回值为false

在开发相关代码方面。 下一步是整理计划,以便按时生成报告,但稍后会更多……

如果您想查看本系列中的其他博客,请在这里看……

  1. 使用Spring跟踪应用程序异常
  2. 使用Spring跟踪异常–第2部分–委托模式
  3. 错误跟踪报告–第3部分–策略和软件包私有