From 29cf7e39947e2bf5ccef57542041c65f0083aea5 Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Wed, 16 Apr 2025 18:33:38 +0800
Subject: [PATCH] 支付通道

---
 src/main/java/com/nq/service/impl/UserWithdrawServiceImpl.java |  353 ++++++++++++++++++++++++++++++++++++++++++----------------
 1 files changed, 254 insertions(+), 99 deletions(-)

diff --git a/src/main/java/com/nq/service/impl/UserWithdrawServiceImpl.java b/src/main/java/com/nq/service/impl/UserWithdrawServiceImpl.java
index f880d95..20d95a2 100644
--- a/src/main/java/com/nq/service/impl/UserWithdrawServiceImpl.java
+++ b/src/main/java/com/nq/service/impl/UserWithdrawServiceImpl.java
@@ -6,9 +6,7 @@
 import com.fasterxml.jackson.databind.ObjectMapper;
 import com.google.gson.Gson;
 import com.nq.dao.*;
-import com.nq.enums.EConfigKey;
 import com.nq.enums.EUserAssets;
-import com.nq.pay.PayUtil;
 import com.nq.pojo.*;
 import com.nq.service.*;
 import com.github.pagehelper.PageHelper;
@@ -19,11 +17,9 @@
 
 import com.nq.utils.*;
 import com.nq.utils.http.HttpClientUtil;
-import com.nq.utils.stock.WithDrawUtils;
 
 import java.io.IOException;
 import java.io.PrintWriter;
-import java.io.UnsupportedEncodingException;
 import java.math.BigDecimal;
 
 import java.time.LocalDate;
@@ -35,9 +31,7 @@
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
 
-import com.nq.utils.timeutil.DateTimeUtil;
 import com.nq.utils.timeutil.TimeUtil;
-import org.apache.commons.collections.map.HashedMap;
 import org.apache.commons.lang3.ObjectUtils;
 import org.apache.commons.lang3.StringUtils;
 
@@ -48,8 +42,6 @@
 
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.stereotype.Service;
-
-import static com.nq.utils.timeutil.DateTimeUtil.STANDARD_FORMAT;
 
 
 @Service("iUserWithdrawService")
@@ -343,100 +335,160 @@
 
 
     @Transactional
-    public ServerResponse updateState(Integer withId, Integer state, String authMsg,
-                                      HttpServletRequest request, HttpServletResponse response) throws Exception {
-        UserWithdraw userWithdraw = this.userWithdrawMapper.selectByPrimaryKey(withId);
-        SiteSetting siteSetting = siteSettingService.getSiteSetting();
-        if (userWithdraw == null) {
-            return ServerResponse.createByErrorMsg("提现订单不存在");
-        }
-        log.info("当前系统设置  {}", new Gson().toJson(siteSetting));
-        if (userWithdraw.getWithStatus().intValue() != 0) {
-            return ServerResponse.createByErrorMsg("提现订单已处理,不要重复操作");
-        }
-        if (state.intValue() == 3 &&
-                StringUtils.isBlank(authMsg)) {
-            return ServerResponse.createByErrorMsg("失败信息必填");
-        }
-        User user = this.userMapper.selectById(userWithdraw.getUserId());
-        if (user == null) {
-            return ServerResponse.createByErrorMsg("用户不存在");
-        }
-        UserAssets userAssets = iUserAssetsServices.assetsByTypeAndUserId("IN", user.getId());
-        if (userAssets == null) {
-            return ServerResponse.createByErrorMsg("用户资金账户不存在");
-        }
-        if (state == 3) {
-            if(userAssets.getAmountToBeCovered().compareTo(BigDecimal.ZERO) > 0){
-                BigDecimal subtract = userWithdraw.getWithAmt().subtract(userAssets.getAmountToBeCovered());
-                if(subtract.compareTo(BigDecimal.ZERO) > 0){
-                    userAssets.setAvailableBalance(userAssets.getAvailableBalance().add(subtract));
-                    userAssets.setFreezeMoney(userAssets.getFreezeMoney().subtract(subtract));
-                    userAssets.setAmountToBeCovered(BigDecimal.ZERO);
+    public ServerResponse updateState(Integer withId, Integer state, String authMsg, HttpServletRequest request, HttpServletResponse response) throws Exception {
+        try {
+            UserWithdraw userWithdraw = this.userWithdrawMapper.selectByPrimaryKey(withId);
+            SiteSetting siteSetting = siteSettingService.getSiteSetting();
+            if (userWithdraw == null) {
+                return ServerResponse.createByErrorMsg("提现订单不存在");
+            }
+            log.info("当前系统设置  {}", new Gson().toJson(siteSetting));
+            if (userWithdraw.getWithStatus().intValue() != 0) {
+                return ServerResponse.createByErrorMsg("提现订单已处理,不要重复操作");
+            }
+            if (state.intValue() == 3 &&
+                    StringUtils.isBlank(authMsg)) {
+                return ServerResponse.createByErrorMsg("失败信息必填");
+            }
+            User user = this.userMapper.selectById(userWithdraw.getUserId());
+            if (user == null) {
+                return ServerResponse.createByErrorMsg("用户不存在");
+            }
+            UserAssets userAssets = iUserAssetsServices.assetsByTypeAndUserId("IN", user.getId());
+            if (userAssets == null) {
+                return ServerResponse.createByErrorMsg("用户资金账户不存在");
+            }
+            if (state == 3) {
+                if(userAssets.getAmountToBeCovered().compareTo(BigDecimal.ZERO) > 0){
+                    BigDecimal subtract = userWithdraw.getWithAmt().subtract(userAssets.getAmountToBeCovered());
+                    if(subtract.compareTo(BigDecimal.ZERO) > 0){
+                        userAssets.setAvailableBalance(userAssets.getAvailableBalance().add(subtract));
+                        userAssets.setFreezeMoney(userAssets.getFreezeMoney().subtract(subtract));
+                        userAssets.setAmountToBeCovered(BigDecimal.ZERO);
+                    }else{
+                        userAssets.setAmountToBeCovered(userAssets.getAmountToBeCovered().subtract(userWithdraw.getWithAmt()));
+                    }
                 }else{
-                    userAssets.setAmountToBeCovered(userAssets.getAmountToBeCovered().subtract(userWithdraw.getWithAmt()));
+                    userAssets.setAvailableBalance(userAssets.getAvailableBalance().add(userWithdraw.getWithAmt()));
+                    userAssets.setFreezeMoney(userAssets.getFreezeMoney().subtract(userWithdraw.getWithAmt()));
                 }
-            }else{
-                userAssets.setAvailableBalance(userAssets.getAvailableBalance().add(userWithdraw.getWithAmt()));
+                int updateCount = userAssetsMapper.updateById(userAssets);
+                if (updateCount > 0) {
+                    log.info("提现失败,返还用户资金成功!");
+                } else {
+                    log.error("返还用户资金出错,抛出异常");
+                    throw new Exception("修改用户资金出错,抛出异常");
+                }
+                userWithdraw.setWithMsg(authMsg);
+                userWithdraw.setWithStatus(2);
+                userWithdraw.setTransTime(new Date());
+                userWithdrawMapper.updateByPrimaryKeySelective(userWithdraw);
+                return ServerResponse.createBySuccessMsg("操作成功!");
+            }else if(state == 2){//手动打款
                 userAssets.setFreezeMoney(userAssets.getFreezeMoney().subtract(userWithdraw.getWithAmt()));
+                userAssetsMapper.updateById(userAssets);
+                userWithdraw.setWithStatus(1);
+                userWithdraw.setTransTime(new Date());
+                int updateCount = this.userWithdrawMapper.updateByPrimaryKeySelective(userWithdraw);
+                if (updateCount > 0) {
+                    return ServerResponse.createBySuccessMsg("操作成功!");
+                }
+            }else if(state == 1){//走代付
+                return getObjectServerResponseOne(withId, request, response, userWithdraw, user, userAssets);
+            }else if(state == 4){//代付 2
+                return getObjectServerResponseTwo(withId, request, response, userWithdraw, user, userAssets);
+            }else{
+                return ServerResponse.createBySuccessMsg("请选择对应的操作!");
             }
-            int updateCount = userAssetsMapper.updateById(userAssets);
-            if (updateCount > 0) {
-                log.info("提现失败,返还用户资金成功!");
-            } else {
-                log.error("返还用户资金出错,抛出异常");
-                throw new Exception("修改用户资金出错,抛出异常");
-            }
-            userWithdraw.setWithMsg(authMsg);
-            userWithdraw.setWithStatus(2);
-            userWithdraw.setTransTime(new Date());
-            userWithdrawMapper.updateByPrimaryKeySelective(userWithdraw);
+        }catch (Exception e){
+            log.info("提现失败:"+e.getMessage());
+            throw e;
+        }
+        return ServerResponse.createBySuccessMsg("操作失败!");
+    }
+
+    private ServerResponse getObjectServerResponseTwo(Integer withId, HttpServletRequest request, HttpServletResponse response, UserWithdraw userWithdraw, User user, UserAssets userAssets) throws IOException {
+        String orderNumber = getOrderTime();
+        String result = payForAnOrderTwo(request, response,user, userWithdraw,orderNumber);
+
+        // 创建 ObjectMapper 实例
+        ObjectMapper objectMapper = new ObjectMapper();
+
+        // 将 JSON 字符串转换为实体类对象
+        PayoutResponse payResponse = objectMapper.readValue(result, PayoutResponse.class);
+        if (payResponse.getCode() == 1) {
+            log.error("代付打款失败!失败原因:"+payResponse.getMessage());
+            return ServerResponse.createByErrorMsg("代付打款失败!失败原因:"+payResponse.getMessage());
+        }
+
+        TransferResponse transferResponse = new TransferResponse();
+        transferResponse.setRespCode(String.valueOf(payResponse.getCode()));
+        transferResponse.setSignType("代付2");
+        transferResponse.setSign("代付2");
+        transferResponse.setErrorMsg(String.valueOf(payResponse.getErrno()));
+        transferResponse.setMerTransferId(orderNumber);
+        transferResponse.setTransferAmount(userWithdraw.getWithAmt());
+        // 获取当前日期和时间
+        LocalDateTime currentDateTime = LocalDateTime.now();
+        // 定义日期时间格式
+        DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
+        // 将当前时间格式化为字符串
+        String formattedDate = currentDateTime.format(formatter);
+        transferResponse.setApplyDate(formattedDate);
+        transferResponse.setTradeNo(payResponse.getData().getOrderNumber());
+        transferResponse.setTradeResult(0);
+        transferResponse.setCallbackState(0);
+        transferResponse.setUserId(user.getId());
+        transferResponse.setCreatedAt(new Date());
+        transferResponse.setWithId(withId);
+        transferResponseService.save(transferResponse);
+
+        userAssets.setFreezeMoney(userAssets.getFreezeMoney().subtract(userWithdraw.getWithAmt()));
+        userAssetsMapper.updateById(userAssets);
+        userWithdraw.setWithStatus(4);
+        userWithdraw.setTransTime(new Date());
+        int updateCount = this.userWithdrawMapper.updateByPrimaryKeySelective(userWithdraw);
+        if (updateCount > 0) {
             return ServerResponse.createBySuccessMsg("操作成功!");
-        }else if(state == 2){//手动打款
-            userAssets.setFreezeMoney(userAssets.getFreezeMoney().subtract(userWithdraw.getWithAmt()));
-            userAssetsMapper.updateById(userAssets);
-            userWithdraw.setWithStatus(1);
-            userWithdraw.setTransTime(new Date());
-            int updateCount = this.userWithdrawMapper.updateByPrimaryKeySelective(userWithdraw);
-            if (updateCount > 0) {
-                return ServerResponse.createBySuccessMsg("操作成功!");
-            }
-        }else if(state == 1){//走代付
-            String result = payForAnOrder(request, response, userWithdraw);
-            if(StringUtils.isEmpty(result)){
-                return ServerResponse.createByErrorMsg("代付打款失败!");
-            }
-            ObjectMapper objectMapper = new ObjectMapper();
+        }
+        return ServerResponse.createBySuccessMsg("操作失败!");
+    }
 
-            // 将 JSON 字符串转换为实体类对象
-            TransferResponseBo transferResponseBo = objectMapper.readValue(result, TransferResponseBo.class);
-            if(transferResponseBo.getRespCode().equals("FAIL")){
-                log.error("代付下单失败:"+result);
-                return ServerResponse.createByErrorMsg("代付下单失败:",request);
-            }
-            TransferResponse transferResponse = new TransferResponse();
-            transferResponse.setRespCode(transferResponseBo.getRespCode());
-            transferResponse.setSignType(transferResponseBo.getSignType());
-            transferResponse.setSign(transferResponseBo.getSign());
-            transferResponse.setMerTransferId(transferResponseBo.getMerTransferId());
-            transferResponse.setTransferAmount(new BigDecimal(transferResponseBo.getTransferAmount()));
-            transferResponse.setApplyDate(transferResponseBo.getApplyDate());
-            transferResponse.setTradeNo(transferResponseBo.getTradeNo());
-            transferResponse.setTradeResult(0);
-            transferResponse.setCallbackState(0);
-            transferResponse.setUserId(user.getId());
-            transferResponse.setCreatedAt(new Date());
-            transferResponse.setWithId(withId);
-            transferResponseService.save(transferResponse);
+    private ServerResponse<Object> getObjectServerResponseOne(Integer withId, HttpServletRequest request, HttpServletResponse response, UserWithdraw userWithdraw, User user, UserAssets userAssets) throws IOException {
+        String result = payForAnOrder(request, response, userWithdraw);
+        if (StringUtils.isEmpty(result)) {
+            return ServerResponse.createByErrorMsg("代付打款失败!");
+        }
+        ObjectMapper objectMapper = new ObjectMapper();
 
-            userAssets.setFreezeMoney(userAssets.getFreezeMoney().subtract(userWithdraw.getWithAmt()));
-            userAssetsMapper.updateById(userAssets);
-            userWithdraw.setWithStatus(4);
-            userWithdraw.setTransTime(new Date());
-            int updateCount = this.userWithdrawMapper.updateByPrimaryKeySelective(userWithdraw);
-            if (updateCount > 0) {
-                return ServerResponse.createBySuccessMsg("操作成功!");
-            }
+        // 将 JSON 字符串转换为实体类对象
+        TransferResponseBo transferResponseBo = objectMapper.readValue(result, TransferResponseBo.class);
+        if(transferResponseBo.getRespCode().equals("FAIL")){
+            log.error("代付下单失败:"+result);
+            return ServerResponse.createByErrorMsg("代付下单失败:", request);
+        }
+        TransferResponse transferResponse = new TransferResponse();
+        transferResponse.setRespCode(transferResponseBo.getRespCode());
+        transferResponse.setSignType(transferResponseBo.getSignType());
+        transferResponse.setSign(transferResponseBo.getSign());
+        transferResponse.setMerTransferId(transferResponseBo.getMerTransferId());
+        transferResponse.setTransferAmount(new BigDecimal(transferResponseBo.getTransferAmount()));
+        transferResponse.setApplyDate(transferResponseBo.getApplyDate());
+        transferResponse.setTradeNo(transferResponseBo.getTradeNo());
+        transferResponse.setTradeResult(0);
+        transferResponse.setCallbackState(0);
+        transferResponse.setUserId(user.getId());
+        transferResponse.setCreatedAt(new Date());
+        transferResponse.setWithId(withId);
+        transferResponseService.save(transferResponse);
+
+        userAssets.setFreezeMoney(userAssets.getFreezeMoney().subtract(userWithdraw.getWithAmt()));
+        userAssetsMapper.updateById(userAssets);
+        userWithdraw.setWithStatus(4);
+        userWithdraw.setTransTime(new Date());
+        int updateCount = this.userWithdrawMapper.updateByPrimaryKeySelective(userWithdraw);
+        if (updateCount > 0) {
+            return ServerResponse.createBySuccessMsg("操作成功!");
         }
         return ServerResponse.createBySuccessMsg("操作失败!");
     }
@@ -467,7 +519,7 @@
         reqMap.put("sign_type", "MD5");
 
         String reqUrl = "https://api.watchglbpay.com/pay/transfer";
-        String merchant_key = "ZGZY3REWQJLAWRCRTHWQVGWYPMD878KQ";
+        String merchant_key = "TKFMXNSNKDP0RUFEKV44SW411VUNDZLG";
 
         String sign = SignAPI.sign(signStr, merchant_key);
 
@@ -482,6 +534,37 @@
         return result;
     }
 
+
+    public String payForAnOrderTwo(HttpServletRequest request, HttpServletResponse response, User user, UserWithdraw userWithdraw, String orderNumber) throws IOException {
+        request.setCharacterEncoding("UTF-8");
+        // 创建一个Map来存储请求参数
+        Map<String, String> reqMap = new HashMap<String, String>();
+
+        // 填充Map参数
+        reqMap.put("merchantid", "T805673557385213");             // 商户号
+        reqMap.put("out_trade_no",orderNumber );      // 商户订单号
+        // 转换为 BigDecimal
+        BigDecimal amount = new BigDecimal(String.valueOf(userWithdraw.getWithAmt()));
+
+        // 保留两位小数,四舍五入
+        amount = amount.setScale(2, BigDecimal.ROUND_HALF_UP);
+        reqMap.put("total_fee", String.valueOf(amount));              // 交易金额(保留两位小数)
+        reqMap.put("notify_url", "https://www.example.com/notify"); // 异步通知地址
+        reqMap.put("timestamp", String.valueOf(System.currentTimeMillis())); // 时间戳
+        reqMap.put("payment_mode", "IMPS");             // 代付模式(IMPS)
+        reqMap.put("account_number", userWithdraw.getBankNo());     // 账号
+        reqMap.put("ifsc", userWithdraw.getBankName());                 // IFSC
+        reqMap.put("customer_name", StringUtils.isEmpty(UserNameUtil.formatCustomerName(user.getNickName())) ? "IsNotSet" : UserNameUtil.formatCustomerName(user.getNickName()));         // 客户姓名(必须是英文,去除空格)
+        reqMap.put("customer_mobile", user.getPhone());    // 客户手机号
+        reqMap.put("customer_email", "test@gmail.com");    // 客户手机号
+        // 生成签名
+        String sign = SignatureGeneratorUtil.generateSign(reqMap,"0cfc8e1a446a1e5214b4032f2d6007e2");
+        reqMap.put("sign", sign);
+        String reqUrl = "https://v2.fastechservicepro.com/payout/unifiedorder";
+        String result = HttpClientUtil.doPost(reqUrl, reqMap, "utf-8");
+        System.out.println("result值:" + result);
+        return result;
+    }
     public String generatePayOrderId() {
         // 获取当前时间戳(毫秒)
         long timestamp = System.currentTimeMillis();
@@ -546,13 +629,12 @@
                     .eq(TransferResponse::getTradeResult, 0)
                     .eq(TransferResponse::getCallbackState, 0)
             );
-
             if(ObjectUtils.isNotEmpty(transferResponse)){
                 UserAssets userAssets = iUserAssetsServices.assetsByTypeAndUserId("IN", transferResponse.getUserId());
                 UserWithdraw userWithdraw = this.userWithdrawMapper.selectByPrimaryKey(transferResponse.getWithId());
 
 
-                if (transferResponse.getRespCode().equals("SUCCESS")) {
+                if (transferResponse.getRespCode().equals("SUCCESS") && (vo.getTradeResult().equals(1) || vo.getTradeResult().equals("1"))) {
                     transferResponse.setTradeResult(1);
                     transferResponse.setCallbackState(1);
                     transferResponseService.updateById(transferResponse);
@@ -595,7 +677,7 @@
                     } else {
                         log.error("返还用户资金出错,抛出异常");
                     }
-                    userWithdraw.setWithMsg("代付验证失败");
+                    userWithdraw.setWithMsg("代付验证失败"+",回调信息【"+vo.toString()+"】");
                     userWithdraw.setWithStatus(2);
                     userWithdraw.setTransTime(new Date());
                     userWithdrawMapper.updateByPrimaryKeySelective(userWithdraw);
@@ -610,6 +692,79 @@
             }
         }
     }
+    @Override
+    public void noticePaymentTwo(PaymentCallbackTwo vo, HttpServletResponse response) throws IOException {
+        log.info("代付回调信息:"+vo.toString());
+        synchronized (vo.getOrder_number()){
+            TransferResponse transferResponse = transferResponseService.getOne(new LambdaQueryWrapper<>(TransferResponse.class)
+                    .eq(TransferResponse::getMerTransferId, vo.getOut_trade_no())
+                    .eq(TransferResponse::getTradeNo, vo.getOrder_number())
+                    .eq(TransferResponse::getTradeResult, 0)
+                    .eq(TransferResponse::getCallbackState, 0)
+            );
 
+            if(ObjectUtils.isNotEmpty(transferResponse)){
+                UserAssets userAssets = iUserAssetsServices.assetsByTypeAndUserId("IN", transferResponse.getUserId());
+                UserWithdraw userWithdraw = this.userWithdrawMapper.selectByPrimaryKey(transferResponse.getWithId());
+
+
+                if (transferResponse.getRespCode().equals(1) && vo.getStatus().equals("payout_success")) {
+                    transferResponse.setTradeResult(1);
+                    transferResponse.setCallbackState(1);
+                    transferResponseService.updateById(transferResponse);
+
+                    userWithdraw.setWithStatus(1);
+                    userWithdraw.setTransTime(new Date());
+                    userWithdrawMapper.updateByPrimaryKeySelective(userWithdraw);
+
+                    log.info("代付回调----成功");
+                    PrintWriter pw = response.getWriter();
+                    pw.print("success");
+                    pw.flush();
+                    pw.close(); // 验签成功,响应SUCCESS
+                    return;
+                } else if(vo.getStatus().equals("payout_fail")){
+                    if (userAssets == null) {
+                        log.error("用户资金账户不存在!");
+                        PrintWriter pw = response.getWriter();
+                        pw.print("Signature Error");
+                        pw.flush();
+                        pw.close();
+                        return;
+                    }
+                    if(userAssets.getAmountToBeCovered().compareTo(BigDecimal.ZERO) > 0){
+                        BigDecimal subtract = userWithdraw.getWithAmt().subtract(userAssets.getAmountToBeCovered());
+                        if(subtract.compareTo(BigDecimal.ZERO) > 0){
+                            userAssets.setAvailableBalance(userAssets.getAvailableBalance().add(subtract));
+                            userAssets.setFreezeMoney(userAssets.getFreezeMoney().subtract(subtract));
+                            userAssets.setAmountToBeCovered(BigDecimal.ZERO);
+                        }else{
+                            userAssets.setAmountToBeCovered(userAssets.getAmountToBeCovered().subtract(userWithdraw.getWithAmt()));
+                        }
+                    }else{
+                        userAssets.setAvailableBalance(userAssets.getAvailableBalance().add(userWithdraw.getWithAmt()));
+                        userAssets.setFreezeMoney(userAssets.getFreezeMoney().subtract(userWithdraw.getWithAmt()));
+                    }
+                    int updateCount = userAssetsMapper.updateById(userAssets);
+                    if (updateCount > 0) {
+                        log.info("提现失败,返还用户资金成功!");
+                    } else {
+                        log.error("返还用户资金出错,抛出异常");
+                    }
+                    userWithdraw.setWithMsg("代付2验证失败:"+vo.getFail_info()+",回调信息【"+vo.toString()+"】");
+                    userWithdraw.setWithStatus(2);
+                    userWithdraw.setTransTime(new Date());
+                    userWithdrawMapper.updateByPrimaryKeySelective(userWithdraw);
+                    transferResponse.setTradeResult(2);
+                    transferResponse.setCallbackState(2);
+                    transferResponseService.updateById(transferResponse);
+                    PrintWriter pw = response.getWriter();
+                    pw.print("Signature Error");
+                    pw.flush();
+                    pw.close();
+                }
+            }
+        }
+    }
 }
 

--
Gitblit v1.9.3