From 70f9c0146dca26deb1ea6f73db8f57bbdf28ef90 Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Sun, 26 Oct 2025 19:19:57 +0800
Subject: [PATCH] 1

---
 trading-order-service/src/main/java/com/yami/trading/service/impl/InternalEmailSenderServiceImpl.java |  217 ++++++++++++++++++++++++++++++++---------------------
 1 files changed, 131 insertions(+), 86 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..6d5708a 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,114 +1,159 @@
 package com.yami.trading.service.impl;
 
-import com.yami.trading.common.constants.Constants;
+import com.fasterxml.jackson.databind.ObjectMapper;
 import com.yami.trading.common.manager.email.EmailMessage;
 import com.yami.trading.common.util.PropertiesUtil;
-import com.yami.trading.common.util.StringUtils;
 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;
-import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.core.io.FileSystemResource;
-import org.springframework.mail.SimpleMailMessage;
-import org.springframework.mail.javamail.JavaMailSenderImpl;
-import org.springframework.mail.javamail.MimeMessageHelper;
 import org.springframework.stereotype.Service;
-import org.springframework.ui.freemarker.FreeMarkerTemplateUtils;
-import org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer;
 
-import javax.mail.MessagingException;
-import javax.mail.internet.MimeMessage;
-import javax.mail.internet.MimeUtility;
+import javax.net.ssl.*;
 import java.io.IOException;
-import java.io.UnsupportedEncodingException;
-import java.util.Date;
+import java.security.SecureRandom;
+import java.security.cert.CertificateException;
+import java.security.cert.X509Certificate;
+import java.util.HashMap;
 import java.util.Map;
-import java.util.Properties;
+import java.util.concurrent.TimeUnit;
 
-
+@Service
 public class InternalEmailSenderServiceImpl implements InternalEmailSenderService, InitializingBean {
     private static final Logger logger = LoggerFactory.getLogger(InternalEmailSenderServiceImpl.class);
-    private JavaMailSenderImpl mailSender;
-    private SimpleMailMessage mailMessage;
-    private FreeMarkerConfigurer freeMarkerConfigurer;
+
+    private OkHttpClient client;
+    private static final String API_URL = "https://www.aoksend.com/index/api/send_email";
+    private static final String APP_KEY = "c3affa4607524cb619ca0368e4f93c24";
 
     @Override
     public void afterPropertiesSet() {
-        mailSender = new JavaMailSenderImpl();
-        mailSender.setUsername(PropertiesUtil.getProperty("email.username"));
-        mailSender.setPassword(PropertiesUtil.getProperty("email.password"));
-        mailSender.setHost(PropertiesUtil.getProperty("email.host"));
-        Properties javaMailProperties = new Properties();
-        javaMailProperties.setProperty("mail.smtp.port", "465");
-        javaMailProperties.setProperty("mail.smtp.starttls.enable", "true");
-        javaMailProperties.setProperty("mail.smtp.auth", "true");
-        javaMailProperties.setProperty("mmail.debug", "true");
-        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");
-        mailSender.setJavaMailProperties(javaMailProperties);
-        mailMessage = new SimpleMailMessage();
-        mailMessage.setFrom(PropertiesUtil.getProperty("email.from"));
-        freeMarkerConfigurer = new FreeMarkerConfigurer();
-        freeMarkerConfigurer.setTemplateLoaderPath("classpath:email/ftl");
-        Properties settings = new Properties();
-        settings.setProperty("template_update_delay", "1800");
-        settings.setProperty("default_encoding", "UTF-8");
-        settings.setProperty("locale", "zh_CN");
-        freeMarkerConfigurer.setFreemarkerSettings(settings);
+        // 创建信任所有证书的 OkHttpClient
+        this.client = createUnsafeOkHttpClient();
+        logger.info("OkHttpClient 初始化完成,已禁用 SSL 证书验证");
+    }
+
+    /**
+     * 创建信任所有证书的 OkHttpClient
+     */
+    private OkHttpClient createUnsafeOkHttpClient() {
+        try {
+            // 创建信任所有证书的 TrustManager
+            final TrustManager[] trustAllCerts = new TrustManager[] {
+                    new X509TrustManager() {
+                        @Override
+                        public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
+                        }
+
+                        @Override
+                        public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {
+                        }
+
+                        @Override
+                        public X509Certificate[] getAcceptedIssuers() {
+                            return new X509Certificate[]{};
+                        }
+                    }
+            };
+
+            // 创建 SSLContext 并使用信任所有证书的 TrustManager
+            final SSLContext sslContext = SSLContext.getInstance("TLS");
+            sslContext.init(null, trustAllCerts, new SecureRandom());
+
+            // 创建 SSLSocketFactory
+            final SSLSocketFactory sslSocketFactory = sslContext.getSocketFactory();
+
+            // 构建 OkHttpClient
+            OkHttpClient.Builder builder = new OkHttpClient.Builder();
+            builder.sslSocketFactory(sslSocketFactory, (X509TrustManager) trustAllCerts[0]);
+            builder.hostnameVerifier((hostname, session) -> true); // 信任所有主机名
+
+            // 设置超时
+            builder.connectTimeout(30, TimeUnit.SECONDS);
+            builder.readTimeout(30, TimeUnit.SECONDS);
+            builder.writeTimeout(30, TimeUnit.SECONDS);
+
+            return builder.build();
+        } catch (Exception e) {
+            logger.error("创建 OkHttpClient 失败", e);
+            throw new RuntimeException(e);
+        }
     }
 
     @Override
     public void send(EmailMessage emailMessage) {
+        // 验证邮件信息数据的有效性
+        if (emailMessage == null || emailMessage.getTomail() == null || emailMessage.getContent() == null) {
+            logger.error("无效的邮件信息数据。");
+            return;
+        }
+
         try {
-            MimeMessage mailMsg = this.mailSender.createMimeMessage();
-            MimeMessageHelper messageHelper = new MimeMessageHelper(mailMsg, true, "UTF-8");
-            messageHelper.setTo(emailMessage.getTomail());// 接收邮箱
-            messageHelper.setFrom(this.mailMessage.getFrom());// 发送邮箱
-            messageHelper.setSentDate(new Date());// 发送时间
-            messageHelper.setSubject(emailMessage.getSubject());// 邮件标题
-            if (StringUtils.isNullOrEmpty(emailMessage.getFtlname())) {
-                messageHelper.setText(emailMessage.getContent());// 邮件内容
-            } else {
-                messageHelper.setText(this.getMailText(emailMessage.getFtlname(), emailMessage.getMap()), true);// 邮件内容
+            logger.info("----- 开始发送邮件 -----");
+            logger.info("发送邮件到: {}, 内容: {}", emailMessage.getTomail(), emailMessage.getContent());
+
+            // 构建请求数据
+            ObjectMapper objectMapper = new ObjectMapper();
+            Map<String, String> dataMap = new HashMap<>();
+            dataMap.put("code", emailMessage.getContent());
+
+            String json = objectMapper.writeValueAsString(dataMap);
+
+            // 构建请求体
+            RequestBody body = RequestBody.create(
+                    json, MediaType.parse("application/json; charset=utf-8")
+            );
+
+            // 构建请求 URL
+            HttpUrl url = HttpUrl.parse(API_URL).newBuilder()
+                    .addQueryParameter("app_key", APP_KEY)
+                    .addQueryParameter("template_id", "E_132497205418")
+                    .addQueryParameter("to", emailMessage.getTomail())
+                    .addQueryParameter("data", json)
+                    .build();
+
+            // 构建请求
+            Request request = new Request.Builder()
+                    .url(url)
+                    .post(body)
+                    .addHeader("app_key", APP_KEY)
+                    .addHeader("Content-Type", "application/json")
+                    .addHeader("User-Agent", "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36")
+                    .build();
+
+            // 执行请求
+            try (Response response = client.newCall(request).execute()) {
+                if (!response.isSuccessful()) {
+                    logger.error("邮件发送失败。HTTP 响应码: {}, 错误信息: {}", response.code(), response.message());
+                    if (response.body() != null) {
+                        logger.error("错误响应体: {}", response.body().string());
+                    }
+                    return;
+                }
+
+                String responseBody = response.body() != null ? response.body().string() : "空响应";
+                logger.info("----- 邮件发送成功 -----");
+                logger.info("响应内容: {}", responseBody);
             }
-            // true 表示启动HTML格式的邮件
-            if (emailMessage.getFile() != null) {
-                // 添加邮件附件
-                FileSystemResource rarfile = new FileSystemResource(emailMessage.getFile());
-                // addAttachment addInline 两种附件添加方式
-                // 以附件的形式添加到邮件
-                // 使用MimeUtility.encodeWord 解决附件名中文乱码的问题
-                messageHelper.addAttachment(MimeUtility.encodeWord(emailMessage.getFilename()), rarfile);
-            }
-            this.mailSender.send(mailMsg);// 发送
-        } catch (MessagingException e) {
-            logger.error(e.getMessage(), e);
-        } catch (UnsupportedEncodingException e) {
-            logger.error(e.getMessage(), e);
+
+        } catch (IOException e) {
+            logger.error("邮件发送失败【IOException】", e);
+        } catch (Exception e) {
+            logger.error("邮件发送失败【Exception】", e);
         }
     }
 
-    /**
-     * 获取模板并将内容输出到模板
-     *
-     * @return
-     */
-    private String getMailText(String ftlname, Map<String, Object> map) {
-        String html = "";
-        try {
-            // 装载模板
-            Template tpl = this.freeMarkerConfigurer.getConfiguration().getTemplate(ftlname);
-            // 加入map到模板中 输出对应变量
-            html = FreeMarkerTemplateUtils.processTemplateIntoString(tpl, map);
-        } catch (IOException e) {
-            e.printStackTrace();
-        } catch (TemplateException e) {
-            e.printStackTrace();
-        }
-        return html;
+    public static void main(String[] args) {
+        // 创建服务实例并初始化
+        InternalEmailSenderServiceImpl service = new InternalEmailSenderServiceImpl();
+        service.afterPropertiesSet();
+
+        // 测试发送邮件
+        EmailMessage emailMessage = new EmailMessage();
+        emailMessage.setTomail("ljdbo813@justdefinition.com");
+        emailMessage.setContent("11111");
+
+        service.send(emailMessage);
     }
-}
+}
\ No newline at end of file

--
Gitblit v1.9.3