1.引入pom依赖
<!-- 邮箱 --> <dependency> <groupId>org.apache.commons</groupId> <artifactId>
commons-email</artifactId> <version>1.4</version> </dependency> <!-- easyexcel--
> <dependency> <groupId>cn.afterturn</groupId> <artifactId>easypoi-spring-boot-
starter</artifactId> <version>4.0.0</version> </dependency> <dependency> <
groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>4.1.2</
version> </dependency>
1.创建邮箱是实体类`
import lombok.Data; import java.util.List; /** * 创建邮箱实体类 * * @author ZL */
@Data public class CreateExcelSendEmailVo<T> { /** * 生成excel的数据 */ private List<
T>dataList; /** * excel的表头 */ private List<String> tableHeadList; /** * 邮件的标题 */
private String emailTitle; /** * 邮件内容 */ private String emailContent; /** *
邮件收件人邮箱,支持多个收件人邮箱 */ private List<String> acceptAddressList; }
2.工具类(这里是两个工具类,别看错了)
import com.alibaba.excel.metadata.BaseRowModel; import org.springframework.
stereotype.Component; /** * @author ZL */ @Component public class ExcelFactory<T
extends BaseRowModel> { public ExportExcelUtil<T> createExportExcel() { return
new ExportExcelUtil<>(); } } import com.alibaba.excel.ExcelWriter; import com.
alibaba.excel.metadata.BaseRowModel; import com.alibaba.excel.metadata.Sheet;
import com.alibaba.excel.metadata.Table; import com.alibaba.excel.support.
ExcelTypeEnum; import lombok.extern.slf4j.Slf4j; import org.springframework.
stereotype.Component; import java.io.ByteArrayOutputStream; import java.io.
IOException; import java.util.ArrayList; import java.util.List; /** *
Excel创建工具类 * * @author ZL */ @Component @Slf4j public class ExportExcelUtil<T
extends BaseRowModel> { public ExportExcelUtil() { } /** * 创建excel表 * * @param
out * @param data * @param tableHeadList * @throws IOException */ public void
createExcel(ByteArrayOutputStream out, List<T> data, List<String> tableHeadList)
throws IOException { try { List<List<String>> head = getExcelHead(tableHeadList)
; ExcelWriter writer = new ExcelWriter(null, out, ExcelTypeEnum.XLSX, true);
Table table = new Table(0); table.setHead(head); Sheet sheet1 = new Sheet(1, 0);
sheet1.setAutoWidth(true); sheet1.setSheetName("sheet1"); writer.write(data,
sheet1, table); writer.finish(); out.flush(); } finally { if (out != null) { out
.close(); } } } /** * 创建excel表头 * * @param tableHeadList * @return */ private
List<List<String>> getExcelHead(List<String> tableHeadList) { List<List<String>>
head= new ArrayList<List<String>>(); for (String s : tableHeadList) { List<
String> column = new ArrayList<String>(); column.add(s); head.add(column); }
return head; } }
3.创建邮箱业务类
import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.
annotation.Value; import org.springframework.stereotype.Component; import javax.
activation.DataHandler; import javax.activation.DataSource; import javax.mail.*;
import javax.mail.internet.*; import javax.mail.util.ByteArrayDataSource; import
java.io.ByteArrayInputStream; import java.util.List; import java.util.Properties
; /** * 创建邮箱业务类 * * @author ZL */ @Component @Slf4j public class EmailService {
@Value("${email.userName:null}") private String userName; @Value(
"${email.passWord:null}") private String passWord; /** * 消息发送方法 * @param
acceptAddressList * @param title * @param text * @param affixName * @param
inputstream */ public void sendMsgFileDs(List<String> acceptAddressList, String
title, String text, String affixName, ByteArrayInputStream inputstream) {
Session session = assembleSession(); Message msg = new MimeMessage(session); try
{ msg.setFrom(new InternetAddress(userName)); msg.setSubject(title); Address[]
addressArr= acceptAddressList(acceptAddressList); msg.setRecipients(Message.
RecipientType.TO, addressArr); MimeBodyPart contentPart = (MimeBodyPart)
createContent(text, inputstream, affixName);//参数为正文内容和附件流 MimeMultipart mime =
new MimeMultipart("mixed"); mime.addBodyPart(contentPart); msg.setContent(mime);
Transport.send(msg); } catch (Exception e) { log.error("创建消息失败,{}",e); } } /**
* 创建邮件消息接收者 * * @param acceptAddressList * @return */ public Address[]
acceptAddressList(List<String> acceptAddressList) { Address[] tos = new
InternetAddress[acceptAddressList.size()]; try { for (int i = 0; i <
acceptAddressList.size(); i++) { tos[i] = new InternetAddress(acceptAddressList.
get(i)); } } catch (AddressException e) { log.error("创建邮件消息接收者失败,{}",e); }
return tos; } /** * 以QQ邮箱为例,邮箱配置类 * * @return */ public Session assembleSession(
) { String host = "host"; String mailStoreType = "smtp"; String popPort = "587";
final Properties props = new Properties(); props.put("mail.smtp.auth", "true");
props.put("mail.smtp.host", host); props.put("mail.store.protocol",
mailStoreType); props.put("mail.smtp.port", popPort); //开启SSL props.put(
"mail.smtp.starttls.enable", "true"); props.put("mail.smtp.socketFactory.port",
popPort); props.put("mail.smtp.socketFactory.fallback", "false"); Session
session= Session.getDefaultInstance(props, new MyAuthenricator(userName,
passWord)); return session; } /** * 输出的excel文件配置 * * @param content * @param
inputstream * @param affixName * @return */ static Part createContent(String
content, ByteArrayInputStream inputstream, String affixName) { MimeBodyPart
contentPart= null; try { contentPart = new MimeBodyPart(); MimeMultipart
contentMultipart= new MimeMultipart("related"); MimeBodyPart htmlPart = new
MimeBodyPart(); htmlPart.setContent(content, "text/html;charset=gbk");
contentMultipart.addBodyPart(htmlPart); //附件部分 MimeBodyPart excelBodyPart = new
MimeBodyPart(); DataSource dataSource = new ByteArrayDataSource(inputstream,
"application/excel"); DataHandler dataHandler = new DataHandler(dataSource);
excelBodyPart.setDataHandler(dataHandler); excelBodyPart.setFileName(MimeUtility
.encodeText(affixName)); contentMultipart.addBodyPart(excelBodyPart);
contentPart.setContent(contentMultipart); } catch (Exception e) { e.
printStackTrace(); } return contentPart; } /** *
用户名密码验证,需要实现抽象类Authenticator的抽象方法PasswordAuthentication *
注意:这里的用户密码不是邮箱登录密码,而是授权码 */ static class MyAuthenricator extends Authenticator {
String u = null; String p = null; public MyAuthenricator(String u, String p) {
this.u = u; this.p = p; } @Override protected PasswordAuthentication
getPasswordAuthentication() { return new PasswordAuthentication(u, p); } } }
4.邮件发送工具类
import com.alibaba.excel.metadata.BaseRowModel; import lombok.extern.slf4j.
Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org
.springframework.stereotype.Component; import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream; import java.util.List; import java.util.
Random; /** * 邮件发送工具类 * * @author ZL */ @Component @Slf4j public class EmailUtil
<T extends BaseRowModel> { @Autowired private ExcelFactory excelFactory;
@Autowired private EmailService emailService; /** * @Author ZL * @Describetion
发送邮件的入口方法 */ public void sendEmail(CreateExcelSendEmailVo vo) { try { log.info(
"开始发送邮件: {}", vo); generateExcelSendEmail(vo.getDataList(), vo.getTableHeadList(
), vo.getAcceptAddressList(), vo.getEmailTitle(), vo.getEmailContent()); log.
info("发送邮件成功"); } catch (Exception e) { log.info("发送邮件失败", e); } } /** *
@Author ZL * @Describetion 生成excel并发送邮件 */ public void generateExcelSendEmail(
List<T> dataList, List<String> tableHeadList, List<String> acceptAddressList,
String emailTitle, String content) { try { ByteArrayOutputStream out = new
ByteArrayOutputStream(); String fileName = "email_" + new Random().nextInt(10000
) + System.currentTimeMillis() + ".xlsx"; //生成excel excelFactory.
createExportExcel().createExcel(out, dataList, tableHeadList); // 发送邮件
emailService.sendMsgFileDs(acceptAddressList, emailTitle, content, fileName, new
ByteArrayInputStream(out.toByteArray())); } catch (Exception e) { log.error(
"发送邮件时出错:{}", e); } } }
4.测试(以上代码可直接使用)
/** * 测试 */ @Test public void test() { CreateExcelSendEmailVo vo = new
CreateExcelSendEmailVo<>(); // 1.构建导出数据内容,这里我是查询自己的用户表 List<Usre> usreList =
userService.getUserList; vo.setDataList(usreList); // 2.设置表头 List<String>
headList= new ArrayList<>(); headList.add("姓名"); headList.add("年龄"); vo.
setTableHeadList(headList); // 3.设置email的title vo.setEmailTitle("测试");
//4.设置email的内容 vo.setEmailContent("学生表"); // 5.设置收件人 List<String>
acceptAddressList= new ArrayList<>(); acceptAddressList.add("[email protected]"); vo.
setAcceptAddressList(acceptAddressList); // 6.发送邮件 emailUtil.sendEmail(vo); }

技术
下载桌面版
GitHub
Microsoft Store
SourceForge
Gitee
百度网盘(提取码:draw)
云服务器优惠
华为云优惠券
京东云优惠券
腾讯云优惠券
阿里云优惠券
Vultr优惠券
站点信息
问题反馈
邮箱:[email protected]
吐槽一下
QQ群:766591547
关注微信