From 496fe07f60137f0296fef15d8b7eb4305891244e Mon Sep 17 00:00:00 2001
From: xuhy <3313886187@qq.com>
Date: 星期一, 21 四月 2025 10:44:16 +0800
Subject: [PATCH] Merge branch 'dev' of http://120.76.84.145:10101/gitblit/r/java/xizang into dev

---
 ruoyi-common/src/main/java/com/ruoyi/common/utils/TencentMailUtil.java |  120 ++++++++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 109 insertions(+), 11 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 99d7bb9..5e7ea1b 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 javax.annotation.Resource;
 import javax.mail.*;
-import javax.mail.internet.InternetAddress;
-import javax.mail.internet.MimeMessage;
+import javax.mail.internet.*;
+import java.io.IOException;
 import java.io.UnsupportedEncodingException;
-import java.util.Properties;
+import java.net.MalformedURLException;
+import java.nio.charset.StandardCharsets;
+import java.nio.file.Files;
+import java.nio.file.Path;
+import java.nio.file.Paths;
+import java.util.*;
+import java.util.concurrent.CompletableFuture;
 
 @Component
 @Slf4j
@@ -43,7 +52,8 @@
         // 访问SMTP服务时需要提供的密码(在控制台选择发信地址进行设置)
         props.put("mail.password", properties.getPassword());
         props.setProperty("mail.smtp.socketFactory.fallback", "false");
-        props.put("mail.smtp.ssl.enable", "false");
+        props.put("mail.smtp.ssl.enable", "true");
+        props.put("mail.smtp.ssl.protocols", "TLSv1.2");
         // 构建授权信息,用于进行SMTP进行身份验证
         Authenticator authenticator = new Authenticator() {
             @Override
@@ -94,17 +104,105 @@
             e.printStackTrace();
             log.error("发送邮件发生异常",e);
         }
-
     }
 
-    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 = new MimeMultipart();
+            // 添加文本消息部分
+            BodyPart messageBodyPart = new MimeBodyPart();
+            messageBodyPart.setHeader("Content-Type", "text/plain;charset=utf-8");
+            messageBodyPart.setContent("您在小程序提交的开票申请已开票成功,请查看附件内容","text/html;charset=UTF-8");
+            multipart.addBodyPart(messageBodyPart);
+            List<Path> tempFilePath = new ArrayList<>();
+            // 添加附件部分
+            for (Map<String, String> map : list) {
+                messageBodyPart = new MimeBodyPart();
+                String filePath = map.get("filePath");
+                String fileName = map.get("fileName");
+                Path path = Paths.get(filePath, fileName);
+                tempFilePath.add(path);
+                FileDataSource source = new FileDataSource(path.toString());
+                messageBodyPart.setDataHandler(new DataHandler(source));
+                // String filenameEncode = MimeUtility.encodeText(fileName, "UTF-8", "base64");
+                // String encodedFileName = Base64.getEncoder().encodeToString(fileName.getBytes(StandardCharsets.UTF_8));
+                // String filenameEncode = MimeUtility.encodeText(encodedFileName);
+                messageBodyPart.setFileName(fileName);
+                messageBodyPart.setHeader("Content-Transfer-Encoding", "base64");
+                messageBodyPart.setHeader("Content-Disposition", "attachment");
+                messageBodyPart.setHeader("Content-Type", "application/octet-stream;name=\"" + fileName + "\"");
+                multipart.addBodyPart(messageBodyPart);
+            }
+            // 设置邮件内容
+            message.setContent(multipart);
+            // 发送邮件
+            Transport.send(message);
+            // 删除临时目录里面的文件
+            for (Path path : tempFilePath) {
+                Files.deleteIfExists(path);
+            }
+        } catch (MessagingException | UnsupportedEncodingException | MalformedURLException e) {
+            log.error("发送邮件发生异常", e);
+            throw new ServiceException("发送邮件失败, 请检查");
+        } catch (IOException e) {
+            throw new RuntimeException("文件下载发生异常");
+        }
+    }
 
+    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", "true");
+        props.put("mail.smtp.ssl.protocols", "TLSv1.2");
+        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);
+            }
+        };
+    }
+
+   // 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