新版仿ok交易所-后端
peter
2025-12-26 94289b9f46e579327d721f6d32c72b417b77f4db
邮箱
5 files modified
101 ■■■■■ changed files
trading-order-admin/src/main/java/com/yami/trading/api/controller/ApiIdentifyingCodeController.java 18 ●●●●● patch | view | raw | blame | history
trading-order-admin/src/main/java/com/yami/trading/api/controller/ApiIndexController.java 10 ●●●●● patch | view | raw | blame | history
trading-order-service/src/main/java/com/yami/trading/EmailServer.java 2 ●●● patch | view | raw | blame | history
trading-order-service/src/main/java/com/yami/trading/service/impl/InternalEmailSenderServiceImpl.java 70 ●●●●● patch | view | raw | blame | history
trading-order-service/src/main/java/com/yami/trading/service/impl/UserServiceImpl.java 1 ●●●● patch | view | raw | blame | history
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);
    }
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);
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);
            }
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();
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("注册失败!");
        }