基于springboot实现了后台定时统计数据报表并将数据生成excel文件作为附件,然后通过邮件发送通知的功能

概述

本例子基于springboot实现了后台定时统计数据报表并将数据生成excel文件作为附件,然后通过邮件发送通知的功能。

详细

一、准备工作

 1、首先注册两个邮箱,一个发送邮箱,一个接收邮箱。

 2、发送邮箱开启IMAP/SMTP/POP3服务,记录得到的授权码

基于springboot实现了后台定时统计数据报表并将数据生成excel文件作为附件,然后通过邮件发送通知的功能_第1张图片

二、项目结构及具体实现

1、项目结构

基于springboot实现了后台定时统计数据报表并将数据生成excel文件作为附件,然后通过邮件发送通知的功能_第2张图片

2、实现代码

配置文件:

server:
  port: 8088

spring:
  mail:
      host: smtp.163.com
      port:
      username: [email protected]
      password: WGWRIGYQSCPGBJCC
      protocol: smtp
      test-connection: true
      default-encoding: UTF-8
email:
  temp: C:/email/
  receiver: [email protected]

邮件服务接口:实现邮件发送功能。

/**
 * 发送带附件的邮件
 *
 * @param receiver 收件人地址
 * @param subject  邮件主题
 * @param content  邮件内容
 * @param filePath 附件地址
 * @param cc       抄送地址
 * @throws MessagingException 邮件发送异常
 */
@Override
public void sendAttachmentsMail(String receiver, String subject, String content, String filePath, String... cc) throws MessagingException {

  MimeMessage message = mailSender.createMimeMessage();

  MimeMessageHelper helper = new MimeMessageHelper(message, true);
  helper.setFrom(sender);
  helper.setTo(receiver);
  helper.setSubject(subject);
  helper.setText(content, true);
  if (ArrayUtil.isNotEmpty(cc)) {
    helper.setCc(cc);
  }
  FileSystemResource file = new FileSystemResource(new File(filePath));
  String fileName = filePath.substring(filePath.lastIndexOf(File.separator)+1);
  helper.addAttachment(fileName, file);

  mailSender.send(message);
}

定时发送任务:本地测试设置每十秒运行一次定时任务。

@Scheduled(cron = "10/20 * * ? * ?")
private void sendEventEmailTask() {
    LOGGER.info("=========启动邮件发送任务=============");
    SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
    String startTime = getPastDate(7) + " 00:00:00";
    String endTime = sdf.format(new Date()) + " 23:59:59";
    String subject = "最近一周的数据";
    this.emailJob(startTime, endTime,subject);
    LOGGER.info("=========结束邮件发送任务=============");
}

三、演示效果

运行项目后等待十秒,查看日志:

基于springboot实现了后台定时统计数据报表并将数据生成excel文件作为附件,然后通过邮件发送通知的功能_第3张图片

查看接收邮箱:

基于springboot实现了后台定时统计数据报表并将数据生成excel文件作为附件,然后通过邮件发送通知的功能_第4张图片

附件:

基于springboot实现了后台定时统计数据报表并将数据生成excel文件作为附件,然后通过邮件发送通知的功能_第5张图片

你可能感兴趣的:(WEB系列,spring,boot,数据库,服务器)