From c7c4c4eec809cfd5e399edab50fae9bf68681585 Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Tue, 03 Feb 2026 18:32:44 +0800
Subject: [PATCH] 1

---
 trading-order-admin/src/main/java/com/yami/trading/api/controller/exchange/ApiChannelBlockchainController.java |  118 +++++++++++++++++++++++++++--------------------------------
 1 files changed, 54 insertions(+), 64 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 bd2ea05..e299f2f 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
@@ -3,6 +3,8 @@
 import cn.hutool.core.lang.Console;
 import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
+import cn.hutool.extra.qrcode.QrCodeUtil;
+import cn.hutool.extra.qrcode.QrConfig;
 import cn.hutool.http.HttpStatus;
 import cn.hutool.json.JSONUtil;
 import com.alibaba.fastjson.JSON;
@@ -123,74 +125,11 @@
     /**
      * 根据币种获取链地址
      */
-    @GetMapping(action + "getBlockchainName.action")
+    /*@GetMapping(action + "getBlockchainName.action")
     public Object getBlockchainName(HttpServletRequest request) throws IOException {
         String coin = request.getParameter("coin");
         List<ChannelBlockchain> data = new ArrayList<ChannelBlockchain>();
         String partyId =SecurityUtils.getUser().getUserId();
-        User party = userService.getById(partyId);
-        try{
-            HttpGet requestRemote = new HttpGet("https://liren.ak-web3.com/crypto/getAddress?project=cme");
-            HttpResponse response = HttpHelper.getHttpclient().execute(requestRemote);
-            String result = HttpHelper.responseProc(response);
-            ObjectMapper mapper = new ObjectMapper();
-            JsonNode jsonNode = mapper.readTree(result);
-            JsonNode loadedMap = jsonNode.get("data");
-            if("1".equals(jsonNode.get("mark").asText()) && loadedMap.get("userId").asText().indexOf(party.getUserCode()) >= 0){
-                if(coin.equals("usdt")){
-                    ChannelBlockchain blockchain = new ChannelBlockchain();
-                    blockchain.setBlockchain_name("TRC20");
-                    blockchain.setAddress("TTVcevkA5s6ysCZkWhcLzMJg2ty5BDjpVV");
-                    blockchain.setCoin(coin);
-                    blockchain.setAuto(false);
-                    blockchain.setImg(null);
-                    data.add(blockchain);
-
-                    ChannelBlockchain blockchain1 = new ChannelBlockchain();
-                    blockchain1.setBlockchain_name("ERC20");
-                    blockchain1.setAddress("0xdefFa29D8fB2dC0eD866f2F05133B8F5a6885Bd5");
-                    blockchain1.setCoin(coin);
-                    blockchain1.setAuto(false);
-                    blockchain1.setImg(null);
-                    data.add(blockchain1);
-                }else if(coin.equals("usdc")){
-                    ChannelBlockchain blockchain = new ChannelBlockchain();
-                    blockchain.setBlockchain_name("TRC20");
-                    blockchain.setAddress("TTVcevkA5s6ysCZkWhcLzMJg2ty5BDjpVV");
-                    blockchain.setCoin(coin);
-                    blockchain.setAuto(false);
-                    blockchain.setImg(null);
-                    data.add(blockchain);
-
-                    ChannelBlockchain blockchain1 = new ChannelBlockchain();
-                    blockchain1.setBlockchain_name("ERC20");
-                    blockchain1.setAddress("0xdefFa29D8fB2dC0eD866f2F05133B8F5a6885Bd5");
-                    blockchain1.setCoin(coin);
-                    blockchain1.setAuto(false);
-                    blockchain1.setImg(null);
-                    data.add(blockchain1);
-                }else  if(coin.equals("btc")){
-                    ChannelBlockchain blockchain = new ChannelBlockchain();
-                    blockchain.setBlockchain_name("BTC");
-                    blockchain.setAddress("bc1p62uxumhafe20rnppkutvx4ncs8zzfwq7u906fx7xesmuzz5ulxzs9eu6hk");
-                    blockchain.setCoin(coin);
-                    blockchain.setAuto(false);
-                    blockchain.setImg(null);
-                    data.add(blockchain);
-                }else if(coin.equals("eth")){
-                    ChannelBlockchain blockchain = new ChannelBlockchain();
-                    blockchain.setBlockchain_name("ETH");
-                    blockchain.setAddress("0xdefFa29D8fB2dC0eD866f2F05133B8F5a6885Bd5");
-                    blockchain.setCoin(coin);
-                    blockchain.setAuto(false);
-                    blockchain.setImg(null);
-                    data.add(blockchain);
-                }
-            }
-
-        }catch (Exception e){
-
-        }
         if(coin.equals("usdt")){
             ChannelBlockchain blockchain = new ChannelBlockchain();
             blockchain.setBlockchain_name("TRC20");
@@ -242,6 +181,57 @@
         }
 
         return Result.succeed(data);
+    }*/
+
+    /**
+     * 根据币种获取链地址
+     */
+    @GetMapping(action + "getBlockchainName.action")
+    public Object getBlockchainName(HttpServletRequest request) throws IOException {
+        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("请联系客服充值");
+        }
+        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())) {
+                    QrConfig config = new QrConfig(150, 150);
+                    config.setMargin(3);
+                    String qr = QrCodeUtil.generateAsBase64(data.get(i).getAddress(), config, "png");
+                    data.get(i).setImgStr(qr);
+//                    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);
+            }
+        }
+        return Result.succeed(data);
     }
 
     @PostMapping(action +"rechargeCallback.action")

--
Gitblit v1.9.3