From 170f393728ec9544e6d58e0eb05182a82f832e3b Mon Sep 17 00:00:00 2001 From: zhangmei <645025773@qq.com> Date: 星期一, 10 三月 2025 13:56:27 +0800 Subject: [PATCH] 开票邮件 --- ruoyi-common/src/main/java/com/ruoyi/common/utils/TencentMailUtil.java | 122 +++++++++++++++++++++++++++++++++++++--- 1 files changed, 112 insertions(+), 10 deletions(-) diff --git a/ruoyi-common/src/main/java/com/ruoyi/common/utils/TencentMailUtil.java b/ruoyi-common/src/main/java/com/ruoyi/common/utils/TencentMailUtil.java index 010c8f2..e418db1 100644 --- a/ruoyi-common/src/main/java/com/ruoyi/common/utils/TencentMailUtil.java +++ b/ruoyi-common/src/main/java/com/ruoyi/common/utils/TencentMailUtil.java @@ -6,11 +6,20 @@ import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; +import javax.activation.DataHandler; +import javax.activation.FileDataSource; +import java.net.URLEncoder; +import javax.activation.URLDataSource; import javax.mail.*; -import javax.mail.internet.InternetAddress; -import javax.mail.internet.MimeMessage; +import javax.mail.internet.*; import java.io.UnsupportedEncodingException; +import java.net.MalformedURLException; +import java.net.URL; +import java.util.List; +import java.util.Map; +import java.util.Objects; import java.util.Properties; +import java.util.concurrent.CompletableFuture; @Component @Slf4j @@ -90,17 +99,110 @@ log.error("发送邮件发生异常",e); throw new ServiceException("发送邮件失败,请检查"); } - } -// public static void main(String[] args) { -// TencentMailUtil tencentMailUtil = new TencentMailUtil(); -// MailProperties properties = new MailProperties(); -// tencentMailUtil.properties = properties; -// tencentMailUtil.send("214491528@qq.com","大学城揽院24栋"); -// -// } + public void sendInvoice(String emailAddress, List<Map<String, String>> list) { + // 异步发送邮件 + CompletableFuture.runAsync(() -> { + try { + sendEmail(emailAddress, list); + } catch (ServiceException e) { + log.error("邮件发送失败", e); + } + }); + } + private void sendEmail(String emailAddress, List<Map<String, String>> list) throws ServiceException { + try { + // 创建邮件会话 + Session mailSession = Session.getInstance(getMailProperties(), getAuthenticator()); + // 创建邮件消息 + MimeMessage message = new MimeMessage(mailSession); + // 设置发件人 + InternetAddress from = new InternetAddress(properties.getUserAddr(), properties.getUserName()); + message.setFrom(from); + + // 设置收件人 + InternetAddress to = new InternetAddress(emailAddress); + message.setRecipient(MimeMessage.RecipientType.TO, to); + + // 设置邮件标题 + message.setSubject("发票"); + + // 创建邮件内容 + Multipart multipart = createMultipart(list); + + // 设置邮件内容 + message.setContent(multipart); + + // 发送邮件 + Transport.send(message); + } catch (MessagingException | UnsupportedEncodingException | MalformedURLException e) { + log.error("发送邮件发生异常", e); + throw new ServiceException("发送邮件失败, 请检查"); + } + } + + private Properties getMailProperties() { + Properties props = new Properties(); + props.put("mail.smtp.auth", "true"); + props.put("mail.smtp.host", properties.getSmtpHost()); + props.put("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory"); + props.put("mail.smtp.socketFactory.port", properties.getSmtpPort()); + props.put("mail.smtp.port", properties.getSmtpPort()); + props.put("mail.user", properties.getUserAddr()); + props.put("mail.password", properties.getPassword()); + props.setProperty("mail.smtp.socketFactory.fallback", "false"); + props.put("mail.smtp.ssl.enable", "false"); + return props; + } + + private Authenticator getAuthenticator() { + return new Authenticator() { + @Override + protected PasswordAuthentication getPasswordAuthentication() { + String userName = properties.getUserAddr(); + String password = properties.getPassword(); + return new PasswordAuthentication(userName, password); + } + }; + } + + private Multipart createMultipart(List<Map<String, String>> list) throws MessagingException, UnsupportedEncodingException, MalformedURLException { + Multipart multipart = new MimeMultipart(); + + // 添加文本消息部分 + BodyPart messageBodyPart = new MimeBodyPart(); + messageBodyPart.setHeader("Content-Type", "text/plain;charset=utf-8"); + multipart.addBodyPart(messageBodyPart); + + // 添加附件部分 + for (Map<String, String> map : list) { + messageBodyPart = new MimeBodyPart(); + String url = map.get("url"); + String fileName = map.get("fileName"); + + URLDataSource source = new URLDataSource(new URL(url)); + messageBodyPart.setDataHandler(new DataHandler(source)); + + String filenameEncode = MimeUtility.encodeText(fileName, "UTF-8", "base64"); + messageBodyPart.setFileName(filenameEncode); + messageBodyPart.setHeader("Content-Transfer-Encoding", "base64"); + messageBodyPart.setHeader("Content-Disposition", "attachment"); + messageBodyPart.setHeader("Content-Type", "application/octet-stream;name=\"" + filenameEncode + "\""); + + multipart.addBodyPart(messageBodyPart); + } + + return multipart; + } + + public static void main(String[] args) throws UnsupportedEncodingException { + TencentMailUtil tencentMailUtil = new TencentMailUtil(); + MailProperties properties = new MailProperties(); + tencentMailUtil.properties = properties; + tencentMailUtil.send("645025773@qq.com","大学城揽院24栋"); + } } -- Gitblit v1.7.1