From 80a32700f145bb88657360d4130362be146c92cf Mon Sep 17 00:00:00 2001
From: dd <gitluke@outlook.com>
Date: Thu, 15 Jan 2026 02:41:52 +0800
Subject: [PATCH] 修改地址
---
trading-order-admin/src/main/java/com/yami/trading/api/controller/exchange/ApiChannelBlockchainController.java | 386 ++++++++++++++++++++++++++++++++++++++++++++----------
1 files changed, 312 insertions(+), 74 deletions(-)
diff --git a/trading-order-admin/src/main/java/com/yami/trading/api/controller/exchange/ApiChannelBlockchainController.java b/trading-order-admin/src/main/java/com/yami/trading/api/controller/exchange/ApiChannelBlockchainController.java
index 1de166c..d3e9f59 100644
--- a/trading-order-admin/src/main/java/com/yami/trading/api/controller/exchange/ApiChannelBlockchainController.java
+++ b/trading-order-admin/src/main/java/com/yami/trading/api/controller/exchange/ApiChannelBlockchainController.java
@@ -1,10 +1,21 @@
package com.yami.trading.api.controller.exchange;
+import cn.hutool.core.lang.Console;
+import cn.hutool.core.util.ObjectUtil;
+import cn.hutool.core.util.StrUtil;
+import cn.hutool.http.HttpStatus;
+import cn.hutool.json.JSONUtil;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.fasterxml.jackson.databind.ObjectMapper;
+import com.yami.trading.api.UD.*;
+import com.yami.trading.api.UD.Address;
import com.yami.trading.bean.exchange.PartyBlockchain;
import com.yami.trading.bean.model.ChannelBlockchain;
+import com.yami.trading.bean.model.RechargeBlockchainOrder;
import com.yami.trading.bean.model.User;
+import com.yami.trading.bean.vo.RechargeAddressVo;
import com.yami.trading.common.constants.Constants;
import com.yami.trading.common.domain.Result;
import com.yami.trading.common.exception.YamiShopBindException;
@@ -12,19 +23,31 @@
import com.yami.trading.common.util.StringUtils;
import com.yami.trading.security.common.util.SecurityUtils;
import com.yami.trading.service.ChannelBlockchainService;
+import com.yami.trading.service.RechargeBlockchainOrderService;
import com.yami.trading.service.exchange.PartyBlockchainService;
import com.yami.trading.service.syspara.SysparaService;
import com.yami.trading.service.user.UserService;
+import com.yami.trading.sys.model.SysUser;
+import com.yami.trading.sys.service.SysUserService;
+import freemarker.template.Configuration;
import io.swagger.annotations.Api;
import lombok.extern.slf4j.Slf4j;
import okhttp3.*;
import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.data.redis.core.RedisTemplate;
+import org.springframework.mail.SimpleMailMessage;
+import org.springframework.mail.javamail.JavaMailSenderImpl;
+import org.springframework.ui.freemarker.FreeMarkerConfigurationFactory;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
+import javax.mail.*;
+import javax.mail.internet.InternetAddress;
+import javax.mail.internet.MimeMessage;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
+import java.math.BigDecimal;
import java.util.*;
import java.util.stream.Collectors;
@@ -43,6 +66,19 @@
UserService userService;
@Autowired
PartyBlockchainService partyBlockchainService;
+ @Autowired
+ RedisTemplate redisTemplate;
+ @Autowired
+ private SysUserService sysUserService;
+ @Autowired
+ RechargeBlockchainOrderService rechargeBlockchainOrderService;
+
+ private final String gateway = "https://sig11.udun.io";
+ private final String merchantKey = "7fd79e4ed59e7c31e1fa2e13d64f7e6c";
+ private final String merchantId = "319563";
+ private final String defaultCallBackUrl = "https://openapi.yanshiz.com/api/channelBlockchain!rechargeCallback.action";
+
+
/**
* 获取所有链地址
@@ -50,41 +86,47 @@
@RequestMapping(action + "list.action")
public Object list() throws IOException {
List<ChannelBlockchain> data = new ArrayList<ChannelBlockchain>();
- String partyId = SecurityUtils.getUser().getUserId();
- User party = userService.getById(partyId);
- List<PartyBlockchain> list = partyBlockchainService.findByUserName(party.getUserName());
- if (null != list && !list.isEmpty()) {
- data = list.stream().map(dict -> {
- String qrImage = dict.getQrImage();
- String chainAddress = dict.getAddress();
- String chainName = dict.getChainName();
- String coinSymbol = dict.getCoinSymbol();
- String autoStr = dict.getAuto();
- boolean auto = autoStr.equals("Y") ? true : false;
- ChannelBlockchain cbc = new ChannelBlockchain();
- cbc.setBlockchainName(chainName);
- cbc.setBlockchain_name(chainName);
- cbc.setAddress(chainAddress);
- cbc.setCoin(coinSymbol);
- cbc.setAuto(auto);
- cbc.setImg(qrImage);
- return cbc;
- }).collect(Collectors.toList());
- }
- if (data.isEmpty()) data = channelBlockchainService.list();
- for (int i = 0; i < data.size(); i++) {
- data.get(i).setBlockchain_name(data.get(i).getBlockchainName());
- if (1 == this.sysparaService.find("can_recharge").getInteger()) {
- // 允许在线充值,展示二维码
- if (!StringUtils.isNullOrEmpty(data.get(i).getImg())) {
- String path = Constants.WEB_URL + "/public/showimg!showImg.action?imagePath=" + data.get(i).getImg();
- data.get(i).setImg(path);
- }
- } else {
- data.get(i).setImg(null);
- data.get(i).setAddress(null);
- }
- }
+ ChannelBlockchain trc20 = new ChannelBlockchain();
+ trc20.setAddress("TCCbY4K2ZeZBjuPTKykQFDDJLALZVu5MDo");
+ trc20.setBlockchainName("trc20");
+ trc20.setBlockchain_name("trc20");
+ trc20.setCoin("usdt");
+ data.add(trc20);
+// String partyId = SecurityUtils.getUser().getUserId();
+// User party = userService.getById(partyId);
+// List<PartyBlockchain> list = partyBlockchainService.findByUserName(party.getUserName());
+// if (null != list && !list.isEmpty()) {
+// data = list.stream().map(dict -> {
+// String qrImage = dict.getQrImage();
+// String chainAddress = dict.getAddress();
+// String chainName = dict.getChainName();
+// String coinSymbol = dict.getCoinSymbol();
+// String autoStr = dict.getAuto();
+// boolean auto = autoStr.equals("Y") ? true : false;
+// ChannelBlockchain cbc = new ChannelBlockchain();
+// cbc.setBlockchainName(chainName);
+// cbc.setBlockchain_name(chainName);
+// cbc.setAddress(chainAddress);
+// cbc.setCoin(coinSymbol);
+// cbc.setAuto(auto);
+// cbc.setImg(qrImage);
+// return cbc;
+// }).collect(Collectors.toList());
+// }
+// if (data.isEmpty()) data = channelBlockchainService.list();
+// for (int i = 0; i < data.size(); i++) {
+// data.get(i).setBlockchain_name(data.get(i).getBlockchainName());
+// if (1 == this.sysparaService.find("can_recharge").getInteger()) {
+// // 允许在线充值,展示二维码
+// if (!StringUtils.isNullOrEmpty(data.get(i).getImg())) {
+// String path = Constants.WEB_URL + "/public/showimg!showImg.action?imagePath=" + data.get(i).getImg();
+// data.get(i).setImg(path);
+// }
+// } else {
+// data.get(i).setImg(null);
+// data.get(i).setAddress(null);
+// }
+// }
return Result.succeed(data);
}
@@ -93,48 +135,177 @@
*/
@GetMapping(action + "getBlockchainName.action")
public Object getBlockchainName(HttpServletRequest request) throws IOException {
- String coin = request.getParameter("coin");
+// String coin = request.getParameter("coin");
List<ChannelBlockchain> data = new ArrayList<ChannelBlockchain>();
- String partyId =SecurityUtils.getUser().getUserId();
- User party = userService.getById(partyId);
- if (0 == this.sysparaService.find("can_recharge").getInteger()) {
- return Result.failed("请联系客服充值");
- }
+// String partyId =SecurityUtils.getUser().getUserId();
+// User party = userService.getById(partyId);
+// if (0 == this.sysparaService.find("can_recharge").getInteger()) {
+// return Result.failed("请联系客服充值");
+// }
- List<PartyBlockchain> list = partyBlockchainService.findByUserNameAndCoinSymbol(party.getUserName(), coin);
- if (null != list && !list.isEmpty()) {
- data = list.stream().map(dict -> {
- String qrImage = dict.getQrImage();
- String chainAddress = dict.getAddress();
- String chainName = dict.getChainName();
- String coinSymbol = dict.getCoinSymbol();
- String autoStr = dict.getAuto();
- boolean auto = autoStr.equals("Y") ? true : false;
- ChannelBlockchain cbc = new ChannelBlockchain();
- cbc.setBlockchain_name(chainName);
- cbc.setAddress(chainAddress);
- cbc.setCoin(coinSymbol);
- cbc.setAuto(auto);
- cbc.setImg(qrImage);
- return cbc;
- }).collect(Collectors.toList());
- }
- if (data.isEmpty()) data = this.channelBlockchainService.findByCoin(coin.toLowerCase());
- for (int i = 0; i < data.size(); i++) {
- data.get(i).setBlockchain_name(data.get(i).getBlockchainName());
- if (1 == this.sysparaService.find("can_recharge").getInteger()) {
- if (!StringUtils.isNullOrEmpty(data.get(i).getImg())) {
- String path = Constants.WEB_URL + "/public/showimg!showImg.action?imagePath=" + data.get(i).getImg();
- data.get(i).setImgStr("/public/showimg!showImg.action?imagePath=" + data.get(i).getImg());
- data.get(i).setImg(path);
- }
- } else {
- data.get(i).setImg(null);
- data.get(i).setImgStr(null);
- data.get(i).setAddress(null);
- }
- }
+// List<PartyBlockchain> list = partyBlockchainService.findByUserNameAndCoinSymbol(party.getUserName(), coin);
+// if (null != list && !list.isEmpty()) {
+// data = list.stream().map(dict -> {
+// String qrImage = dict.getQrImage();
+// String chainAddress = dict.getAddress();
+// String chainName = dict.getChainName();
+// String coinSymbol = dict.getCoinSymbol();
+// String autoStr = dict.getAuto();
+// boolean auto = autoStr.equals("Y") ? true : false;
+// ChannelBlockchain cbc = new ChannelBlockchain();
+// cbc.setBlockchain_name(chainName);
+// cbc.setAddress(chainAddress);
+// cbc.setCoin(coinSymbol);
+// cbc.setAuto(auto);
+// cbc.setImg(qrImage);
+// return cbc;
+// }).collect(Collectors.toList());
+// }
+//
+// //后台设置地址
+// if (data.isEmpty()) data = this.channelBlockchainService.findByCoin(coin.toLowerCase());
+// for (int i = 0; i < data.size(); i++) {
+// data.get(i).setBlockchain_name(data.get(i).getBlockchainName());
+// if (1 == this.sysparaService.find("can_recharge").getInteger()) {
+// if (!StringUtils.isNullOrEmpty(data.get(i).getImg())) {
+// String path = Constants.WEB_URL + "/public/showimg!showImg.action?imagePath=" + data.get(i).getImg();
+// data.get(i).setImgStr("/public/showimg!showImg.action?imagePath=" + data.get(i).getImg());
+// data.get(i).setImg(path);
+// }
+// } else {
+// data.get(i).setImg(null);
+// data.get(i).setImgStr(null);
+// data.get(i).setAddress(null);
+// }
+// }
+
+// String partyId =SecurityUtils.getUser().getUserId();
+// if(!StringUtils.isNotEmpty(partyId)){
+// throw new YamiShopBindException("请登录!");
+// }
+// if (0 == this.sysparaService.find("can_recharge").getInteger()) {
+// return Result.failed("请联系客服充值");
+// }
+// RechargeAddressVo rechargeAddressVo = new RechargeAddressVo();
+//
+// //获取u盾地址
+// //获取商户支持币种
+// List<Coin> coinList = listSupportCoin(merchantId,false);
+// //创建地址
+// coinList.forEach(f->{
+// Address address = new Address();
+// if(f.getName().equals("BTC")){
+// String ress = (String)redisTemplate.opsForValue().get(partyId + "BTC");
+// if(StringUtils.isNotEmpty(ress)){
+// rechargeAddressVo.setAddress(ress);
+// rechargeAddressVo.setCoin(coin);
+// rechargeAddressVo.setBlockchainName(coin);
+// }else{
+// address = createAddress(f.getMainCoinType(),null,null,null);
+// rechargeAddressVo.setAddress(address.getAddress());
+// rechargeAddressVo.setCoin(coin);
+// rechargeAddressVo.setBlockchainName(coin);
+// redisTemplate.opsForValue().set(partyId + "BTC",address.getAddress());
+// }
+// }else if(f.getName().equals("ETH")){
+// String ress = (String)redisTemplate.opsForValue().get(partyId + "ETH");
+// if(StringUtils.isNotEmpty(ress)){
+// rechargeAddressVo.setAddress(ress);
+// rechargeAddressVo.setCoin(coin);
+// rechargeAddressVo.setBlockchainName(coin);
+// }else{
+// address = createAddress(f.getMainCoinType(),null,null,null);
+// rechargeAddressVo.setAddress(address.getAddress());
+// rechargeAddressVo.setCoin(coin);
+// rechargeAddressVo.setBlockchainName(coin);
+// redisTemplate.opsForValue().set(partyId + "ETH",address.getAddress());
+// }
+// }else if(f.getName().equals("USDT")){
+// String ress = (String)redisTemplate.opsForValue().get(partyId + "USDT");
+// if(StringUtils.isNotEmpty(ress)){
+// rechargeAddressVo.setAddress(ress);
+// rechargeAddressVo.setCoin(coin);
+// rechargeAddressVo.setBlockchainName(coin);
+// }else{
+// address = createAddress(f.getMainCoinType(),null,null,null);
+// rechargeAddressVo.setAddress(address.getAddress());
+// rechargeAddressVo.setCoin(coin);
+// rechargeAddressVo.setBlockchainName(coin);
+// redisTemplate.opsForValue().set(partyId + "USDT",address.getAddress());
+// }
+// }
+// });
+// return Result.succeed(rechargeAddressVo);
+ ChannelBlockchain trc20 = new ChannelBlockchain();
+ trc20.setAddress("TThw9XL6jiS9XsU2bae3gWKdJnLJbLydeS");
+ trc20.setBlockchainName("trc20");
+ trc20.setBlockchain_name("trc20");
+ trc20.setCoin("usdt");
+ data.add(trc20);
return Result.succeed(data);
+ }
+
+ public List<Coin> listSupportCoin(String merchantId , boolean showBalance) {
+ Map<String, Object> params = new HashMap<>();
+ params.put("merchantId", merchantId);
+ params.put("showBalance", showBalance);
+ ResultMsg result = JSONUtil.toBean(UdunUtils.post(gateway, merchantKey, ApiPath.SUPPORT_COIN, JSONUtil.toJsonStr(params)), ResultMsg.class);
+ if (result.getCode() != HttpStatus.HTTP_OK) {
+ Console.error(JSONUtil.toJsonStr(result));
+ return null;
+ }
+ return JSONUtil.toList(JSONUtil.parseArray(result.getData()), Coin.class);
+ }
+
+ public Address createAddress(String mainCoinType, String alias, String walletId, String callUrl) throws UdunException {
+ Map<String, String> params = new HashMap<>();
+ params.put("merchantId", merchantId);
+ params.put("coinType", mainCoinType);
+ params.put("callUrl", defaultCallBackUrl);
+ params.put("walletId", walletId);
+ params.put("alias", alias);
+
+ ResultMsg result = JSONUtil.toBean(UdunUtils.post(gateway, merchantKey, ApiPath.CREATE_ADDRESS, StrUtil.format("[{}]", JSONUtil.toJsonStr(params))), ResultMsg.class);
+ if (result.getCode() != HttpStatus.HTTP_OK) {
+ throw new UdunException(result.getCode(), result.getMessage());
+ }
+ return JSONUtil.toBean(result.getData(), Address.class);
+ }
+
+ @RequestMapping(action +"rechargeCallback.action")
+ public ResultMsg rechargeCallback(HttpServletRequest request){
+ String timestamp = request.getParameter("timestamp");
+ String nonce = request.getParameter("nonce");
+ String sign = request.getParameter("sign");
+ String body = request.getParameter("body");
+ try{
+ ObjectMapper objectMapper = new ObjectMapper();
+ Map<String, Object> map = objectMapper.readValue(body, HashMap.class);
+ double amounts = Double.parseDouble(map.get("amount").toString()); // 假设 amount 的值为 1000
+ double decimals = Double.parseDouble(map.get("decimals").toString());
+ double success_amount = amounts / Math.pow(10, decimals);
+ String address = map.get("address").toString();
+
+
+ RechargeBlockchainOrder blockchainOrder = rechargeBlockchainOrderService.getOne(new LambdaQueryWrapper<>(RechargeBlockchainOrder.class)
+ .eq(RechargeBlockchainOrder::getSucceeded, 0)
+ .eq(RechargeBlockchainOrder::getChannelAddress, address).last(" limit 1 "));
+ if(ObjectUtil.isEmpty(blockchainOrder)){
+ ResultMsg resultMsg = new ResultMsg();
+ resultMsg.setCode(200);
+ return resultMsg;
+ }
+ SysUser user = sysUserService.getSysUserById( Long.getLong(blockchainOrder.getPartyId()));
+ rechargeBlockchainOrderService.manualReceipt(1,blockchainOrder.getPartyId(), BigDecimal.valueOf(success_amount),user.getUsername());
+ ResultMsg resultMsg = new ResultMsg();
+ resultMsg.setCode(200);
+ return resultMsg;
+ }catch (Exception e){
+ ResultMsg resultMsg = new ResultMsg();
+ resultMsg.setCode(500);
+ resultMsg.setMessage("回调处理失败");
+ return resultMsg;
+ }
}
/**
@@ -201,4 +372,71 @@
}
}
+
+
+
+ public static void main(String[] args) {
+ // 设置使用系统代理
+ System.setProperty("java.net.useSystemProxies", "true");
+
+ // 从配置文件获取或直接设置邮箱信息
+ final String username = "bingxb52@gmail.com";
+ final String password = "byrxvwitlehuwmjb";
+ final String fromEmail = "bingxb52@gmail.com";
+ String toEmail = "eyedken98@deepmails.org";
+
+ // 创建 JavaMailSender
+ JavaMailSenderImpl mailSender = new JavaMailSenderImpl();
+ mailSender.setUsername(username);
+ mailSender.setPassword(password);
+ mailSender.setHost("smtp.gmail.com");
+ mailSender.setPort(587); // 直接设置端口
+
+ Properties javaMailProperties = new Properties();
+ javaMailProperties.setProperty("mail.smtp.auth", "true");
+ javaMailProperties.setProperty("mail.smtp.starttls.enable", "true");
+ javaMailProperties.setProperty("mail.smtp.starttls.required", "true");
+ javaMailProperties.setProperty("mail.debug", "true");
+
+ // 添加超时设置
+ javaMailProperties.setProperty("mail.smtp.timeout", "30000");
+ javaMailProperties.setProperty("mail.smtp.connectiontimeout", "30000");
+ javaMailProperties.setProperty("mail.smtp.writetimeout", "30000");
+
+ mailSender.setJavaMailProperties(javaMailProperties);
+
+ // 创建邮件消息
+ SimpleMailMessage mailMessage = new SimpleMailMessage();
+ mailMessage.setFrom(fromEmail);
+
+ // 配置 FreeMarker(如果需要发送模板邮件)
+ FreeMarkerConfigurationFactory freeMarkerConfigurer = new FreeMarkerConfigurationFactory();
+ 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);
+
+ try {
+ Configuration freeMarkerConfig = freeMarkerConfigurer.createConfiguration();
+ System.out.println("FreeMarker 配置完成");
+ } catch (Exception e) {
+ System.out.println("FreeMarker 配置失败: " + e.getMessage());
+ }
+
+ // 发送测试邮件
+ try {
+ mailMessage.setTo(toEmail);
+ mailMessage.setSubject("测试邮件主题");
+ mailMessage.setText("这是一封通过Java程序发送的测试邮件。");
+
+ mailSender.send(mailMessage);
+ System.out.println("邮件发送成功!");
+
+ } catch (Exception e) {
+ System.out.println("邮件发送失败:");
+ e.printStackTrace();
+ }
+ }
}
--
Gitblit v1.9.3