From 94289b9f46e579327d721f6d32c72b417b77f4db Mon Sep 17 00:00:00 2001
From: peter <14100000001@qq.com>
Date: Fri, 26 Dec 2025 14:42:03 +0800
Subject: [PATCH] 邮箱
---
trading-order-admin/src/main/java/com/yami/trading/api/controller/ApiIdentifyingCodeController.java | 18 ++++++++
trading-order-service/src/main/java/com/yami/trading/service/impl/InternalEmailSenderServiceImpl.java | 70 ++++++++++++++++++++++++++++++++++-
trading-order-admin/src/main/java/com/yami/trading/api/controller/ApiIndexController.java | 10 ++++
trading-order-service/src/main/java/com/yami/trading/EmailServer.java | 2
trading-order-service/src/main/java/com/yami/trading/service/impl/UserServiceImpl.java | 1
5 files changed, 96 insertions(+), 5 deletions(-)
diff --git a/trading-order-admin/src/main/java/com/yami/trading/api/controller/ApiIdentifyingCodeController.java b/trading-order-admin/src/main/java/com/yami/trading/api/controller/ApiIdentifyingCodeController.java
index 6f47fbb..9b9d94a 100644
--- a/trading-order-admin/src/main/java/com/yami/trading/api/controller/ApiIdentifyingCodeController.java
+++ b/trading-order-admin/src/main/java/com/yami/trading/api/controller/ApiIdentifyingCodeController.java
@@ -1,13 +1,18 @@
package com.yami.trading.api.controller;
import com.yami.trading.common.domain.Result;
+import com.yami.trading.common.manager.email.EmailMessage;
import com.yami.trading.common.util.IPHelper;
import com.yami.trading.service.IdentifyingCodeService;
+import com.yami.trading.service.IdentifyingCodeTimeWindowService;
+import com.yami.trading.service.InternalEmailSenderService;
import io.swagger.annotations.Api;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
+
+import java.util.Random;
@RequestMapping("api/idcode")
@RestController
@@ -16,10 +21,21 @@
@Autowired
private IdentifyingCodeService identifyingCodeService;
+ @Autowired
+ private InternalEmailSenderService internalEmailSenderService;
+ @Autowired
+ private IdentifyingCodeTimeWindowService identifyingCodeTimeWindowService;
@RequestMapping("execute")
public Result execute(@RequestParam String target) {
- identifyingCodeService.send(target, IPHelper.getIpAddr());
+// identifyingCodeService.send(target, IPHelper.getIpAddr());
+ Random random = new Random();
+ String code = String.valueOf(random.nextInt(999999) % 900000 + 100000);
+ this.identifyingCodeTimeWindowService.putAuthCode(target, code);
+ EmailMessage emailMessage = new EmailMessage();
+ emailMessage.setContent(code);
+ emailMessage.setTomail(target);
+ internalEmailSenderService.aokSend(emailMessage);
return Result.succeed(null);
}
diff --git a/trading-order-admin/src/main/java/com/yami/trading/api/controller/ApiIndexController.java b/trading-order-admin/src/main/java/com/yami/trading/api/controller/ApiIndexController.java
index a1ff910..df3ae24 100644
--- a/trading-order-admin/src/main/java/com/yami/trading/api/controller/ApiIndexController.java
+++ b/trading-order-admin/src/main/java/com/yami/trading/api/controller/ApiIndexController.java
@@ -22,6 +22,7 @@
import com.yami.trading.security.common.manager.PasswordManager;
import com.yami.trading.security.common.manager.TokenStore;
import com.yami.trading.security.common.vo.TokenInfoVO;
+import com.yami.trading.service.IdentifyingCodeTimeWindowService;
import com.yami.trading.service.WalletService;
import com.yami.trading.service.syspara.SysparaService;
import com.yami.trading.service.system.LogService;
@@ -29,6 +30,7 @@
import com.yami.trading.service.user.UserService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
+import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.security.crypto.password.PasswordEncoder;
@@ -71,6 +73,8 @@
@Autowired
UserDataService userDataService;
+ @Autowired
+ IdentifyingCodeTimeWindowService identifyingCodeTimeWindowService;
@PostMapping("/login")
@@ -189,7 +193,11 @@
String usercode = model.getUserCode();
// 注册类型:1/手机;2/邮箱;3/用户名;
int type = model.getType();
-
+ String key = username;
+ String authcode = identifyingCodeTimeWindowService.getAuthCode(key);
+ if (StringUtils.isBlank(model.getEmailCode()) ||(authcode == null) || (!authcode.equals(model.getEmailCode()))) {
+ throw new YamiShopBindException("验证码不正确");
+ }
User user = userService.register(model.getUserName(),
passwordEncoder.encode(password)
, model.getUserCode(), model.getType(),false);
diff --git a/trading-order-service/src/main/java/com/yami/trading/EmailServer.java b/trading-order-service/src/main/java/com/yami/trading/EmailServer.java
index 91e1bc6..b7fbdd4 100644
--- a/trading-order-service/src/main/java/com/yami/trading/EmailServer.java
+++ b/trading-order-service/src/main/java/com/yami/trading/EmailServer.java
@@ -90,7 +90,7 @@
public void run() {
try {
- internalEmailSenderService.send(item);
+ internalEmailSenderService.aokSend(item);
} catch (Throwable t) {
logger.error("EmailServer taskExecutor.execute() fail", t);
}
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 33fbcd3..ab7a157 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
@@ -69,8 +69,74 @@
freeMarkerConfigurer.setFreemarkerSettings(settings);
}
+ private static final OkHttpClient client = new OkHttpClient.Builder()
+ .connectTimeout(10, java.util.concurrent.TimeUnit.SECONDS) // 设置连接超时
+ .readTimeout(30, java.util.concurrent.TimeUnit.SECONDS) // 设置读取超时
+ .writeTimeout(30, java.util.concurrent.TimeUnit.SECONDS) // 设置写入超时
+ .build();
private static final String API_URL = "https://www.aoksend.com/index/api/send_email";
- private static final String APP_KEY = "741338dcd2fd58d93fadf74c350cb15b"; // 从环境变量或配置文件中获取
+ private static final String APP_KEY = "9897279416428ea3d940063f76deaed9"; // 从环境变量或配置文件中获取
+
+ public static void main(String[] args) {
+ EmailMessage emailMessage = new EmailMessage();
+ emailMessage.setContent("58889");
+ emailMessage.setTomail("oykegx@swagpapa.com");
+ aokSendTest(emailMessage);
+ }
+ public static void aokSendTest(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_136625161409");
+ 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 aokSend(EmailMessage emailMessage) {
// 验证邮件信息数据的有效性
@@ -86,7 +152,7 @@
// 使用 URL 构建器构建带有查询参数的 URL
HttpUrl.Builder urlBuilder = HttpUrl.parse(API_URL).newBuilder();
urlBuilder.addQueryParameter("app_key", APP_KEY);
- urlBuilder.addQueryParameter("template_id", "E_132465345657");
+ urlBuilder.addQueryParameter("template_id", "E_136625161409");
urlBuilder.addQueryParameter("to", emailMessage.getTomail());
ObjectMapper objectMapper = new ObjectMapper();
diff --git a/trading-order-service/src/main/java/com/yami/trading/service/impl/UserServiceImpl.java b/trading-order-service/src/main/java/com/yami/trading/service/impl/UserServiceImpl.java
index ea4d3b6..973edc8 100644
--- a/trading-order-service/src/main/java/com/yami/trading/service/impl/UserServiceImpl.java
+++ b/trading-order-service/src/main/java/com/yami/trading/service/impl/UserServiceImpl.java
@@ -1293,6 +1293,7 @@
user = new User();
user.setUserName(userName);
}
+
if (user == null) {
throw new YamiShopBindException("注册失败!");
}
--
Gitblit v1.9.3