From 65e26311f3d37d6351b84d1f45ef722fc2be7251 Mon Sep 17 00:00:00 2001
From: peter <14100000001@qq.com>
Date: Wed, 24 Dec 2025 14:30:33 +0800
Subject: [PATCH] 邮箱

---
 trading-order-service/src/main/java/com/yami/trading/service/impl/InternalEmailSenderServiceImpl.java |   70 ++++++++++++++++++++++++++++++++++-
 1 files changed, 68 insertions(+), 2 deletions(-)

diff --git a/trading-order-service/src/main/java/com/yami/trading/service/impl/InternalEmailSenderServiceImpl.java b/trading-order-service/src/main/java/com/yami/trading/service/impl/InternalEmailSenderServiceImpl.java
index 77da9ea..33fbcd3 100644
--- a/trading-order-service/src/main/java/com/yami/trading/service/impl/InternalEmailSenderServiceImpl.java
+++ b/trading-order-service/src/main/java/com/yami/trading/service/impl/InternalEmailSenderServiceImpl.java
@@ -1,5 +1,6 @@
 package com.yami.trading.service.impl;
 
+import com.fasterxml.jackson.databind.ObjectMapper;
 import com.yami.trading.common.constants.Constants;
 import com.yami.trading.common.manager.email.EmailMessage;
 import com.yami.trading.common.util.PropertiesUtil;
@@ -7,6 +8,7 @@
 import com.yami.trading.service.InternalEmailSenderService;
 import freemarker.template.Template;
 import freemarker.template.TemplateException;
+import okhttp3.*;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 import org.springframework.beans.factory.InitializingBean;
@@ -25,6 +27,7 @@
 import java.io.IOException;
 import java.io.UnsupportedEncodingException;
 import java.util.Date;
+import java.util.HashMap;
 import java.util.Map;
 import java.util.Properties;
 
@@ -43,12 +46,17 @@
         mailSender.setHost(PropertiesUtil.getProperty("email.host"));
         Properties javaMailProperties = new Properties();
         javaMailProperties.setProperty("mail.smtp.port", "465");
-        javaMailProperties.setProperty("mail.smtp.starttls.enable", "true");
+        // 1. 禁用STARTTLS(465端口无需)
+        javaMailProperties.setProperty("mail.smtp.starttls.enable", "false");
         javaMailProperties.setProperty("mail.smtp.auth", "true");
-        javaMailProperties.setProperty("mmail.debug", "true");
+        // 2. 修正debug配置
+        javaMailProperties.setProperty("mail.debug", "true");
+        // 3. 明确TLS协议版本
+        javaMailProperties.setProperty("mail.smtp.ssl.protocols", "TLSv1.2");
         javaMailProperties.setProperty("mail.smtp.host", "smtp.gmail.com");
         javaMailProperties.setProperty("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory");
         javaMailProperties.setProperty("mail.smtp.socketFactory.port", "465");
+        javaMailProperties.setProperty("mail.smtp.ssl.enable", "true");
         mailSender.setJavaMailProperties(javaMailProperties);
         mailMessage = new SimpleMailMessage();
         mailMessage.setFrom(PropertiesUtil.getProperty("email.from"));
@@ -61,6 +69,64 @@
         freeMarkerConfigurer.setFreemarkerSettings(settings);
     }
 
+    private static final String API_URL = "https://www.aoksend.com/index/api/send_email";
+    private static final String APP_KEY = "741338dcd2fd58d93fadf74c350cb15b";  // 从环境变量或配置文件中获取
+    @Override
+    public void aokSend(EmailMessage emailMessage) {
+        // 验证邮件信息数据的有效性
+        if (emailMessage == null || emailMessage.getTomail() == null || emailMessage.getContent() == null) {
+            logger.error("无效的邮件信息数据。");
+            return;
+        }
+
+        try {
+            logger.info("----- 开始发送邮件 -----");
+            logger.info("发送邮件到: " + emailMessage.getTomail() + ", 来自: " + emailMessage.getContent());
+
+            // 使用 URL 构建器构建带有查询参数的 URL
+            HttpUrl.Builder urlBuilder = HttpUrl.parse(API_URL).newBuilder();
+            urlBuilder.addQueryParameter("app_key", APP_KEY);
+            urlBuilder.addQueryParameter("template_id", "E_132465345657");
+            urlBuilder.addQueryParameter("to", emailMessage.getTomail());
+
+            ObjectMapper objectMapper = new ObjectMapper();
+            Map<String, String> dataMap = new HashMap<>();
+            dataMap.put("code", emailMessage.getContent());
+
+            String json = objectMapper.writeValueAsString(dataMap);
+            urlBuilder.addQueryParameter("data", json);
+
+            // 构建请求体,使用 POST 方法
+            RequestBody body = RequestBody.create(
+                    json, MediaType.parse("application/json; charset=utf-8")
+            );
+
+            // 构建 POST 请求
+            Request request = new Request.Builder()
+                    .url(urlBuilder.build())
+                    .post(body)  // 使用 POST 方法,并传递请求体
+                    .addHeader("app_key", APP_KEY)
+                    .build();
+
+            // 执行请求
+            try (Response response = client.newCall(request).execute()) {
+                if (!response.isSuccessful()) {
+                    logger.error("邮件发送失败。HTTP 响应码: " + response.code());
+                    return;
+                }
+
+                logger.info("----- 邮件发送成功 -----");
+                // 可选:记录响应体的内容(如果需要)
+                logger.info("响应内容: " + response.body().string());
+            }
+
+        } catch (IOException e) {
+            logger.error("邮件发送失败【IOException】", e);
+        } catch (Exception e) {
+            logger.error("邮件发送失败【Exception】", e);
+        }
+    }
+
     @Override
     public void send(EmailMessage emailMessage) {
         try {

--
Gitblit v1.9.3