From 9486766c806fe1d9e082b2fd02ea1cc558f1b443 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期四, 08 五月 2025 09:21:57 +0800
Subject: [PATCH] bug修改

---
 cloud-server-competition/src/main/java/com/dsh/competition/controller/CompetitionController.java |   57 +++++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 53 insertions(+), 4 deletions(-)

diff --git a/cloud-server-competition/src/main/java/com/dsh/competition/controller/CompetitionController.java b/cloud-server-competition/src/main/java/com/dsh/competition/controller/CompetitionController.java
index 82f7bde..70acfbd 100644
--- a/cloud-server-competition/src/main/java/com/dsh/competition/controller/CompetitionController.java
+++ b/cloud-server-competition/src/main/java/com/dsh/competition/controller/CompetitionController.java
@@ -25,16 +25,14 @@
 import com.dsh.competition.service.IParticipantService;
 import com.dsh.competition.service.IPaymentCompetitionService;
 import com.dsh.competition.service.UserCompetitionService;
-import com.dsh.competition.util.PayMoneyUtil;
-import com.dsh.competition.util.ResultUtil;
-import com.dsh.competition.util.TokenUtil;
-import com.dsh.competition.util.ToolUtil;
+import com.dsh.competition.util.*;
 import io.swagger.annotations.ApiImplicitParam;
 import io.swagger.annotations.ApiImplicitParams;
 import io.swagger.annotations.ApiOperation;
 
 import lombok.Synchronized;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.util.StringUtils;
 import org.springframework.web.bind.annotation.*;
 
 import javax.annotation.Resource;
@@ -42,6 +40,7 @@
 import javax.servlet.http.HttpServletResponse;
 import java.io.OutputStream;
 import java.io.PrintWriter;
+import java.math.BigDecimal;
 import java.text.DateFormat;
 import java.text.SimpleDateFormat;
 import java.util.*;
@@ -461,7 +460,34 @@
                     Competition competition = cttService.getById(paymentCompetition.getCompetitionId());
                     competition.setApplicantsNumber(competition.getApplicantsNumber() + 1);
                     cttService.updateById(competition);
+                    if (competition.getOperatorId()!=null && competition.getOperatorId()!=0){
+                        // 休眠两分钟后再调用分账接口 避免提示订单正在处理中
+                        Thread.sleep(120000);
+                        // 根据运营商id获取对应运营商分账比例 返回格式: 微信分账比例,支付宝分账比例
+                        String proportionByOperatorId = storeClient.getProportionByOperatorId(competition.getOperatorId());
+                        String[] split = proportionByOperatorId.split(",");
+                        String s1 = split[0];
+                        if (!s1.equals("未设置")){
+                            BigDecimal bigDecimal = new BigDecimal(s1);
+                            // 分账比例
+                            BigDecimal bigDecimal1 = bigDecimal.divide(new BigDecimal(100)).setScale(2);
+                            // 微信商户号
+                            String s2 = storeClient.getmerchantNumberByOperatorId(competition.getOperatorId());
+                            String nonce_str = UUIDUtil.getRandomCode(16);
+                            paymentCompetition.setFenzhangOrderNo(nonce_str);
+                            BigDecimal bigDecimal2 = new BigDecimal(paymentCompetition.getAmount());
+                            ResultUtil fenzhang = payMoneyUtil.fenzhang(transaction_id, bigDecimal2.multiply(bigDecimal1), s2,nonce_str,"报名赛事分账");
+                            if (!fenzhang.getCode().equals(200)){
+                                System.err.println("分账失败 原因是:"+fenzhang.getData()+"-"+fenzhang.getMsg());
+                            }else{
+                                paymentCompetition.setFenzhangNo(fenzhang.getData().toString());
+                                paymentCompetition.setFenzhangAmount(bigDecimal2.multiply(bigDecimal1));
+                                paymentCompetitionService.updateById(paymentCompetition);
+                            }
+                        }
+                    }
                 }
+
 
                 PrintWriter out = response.getWriter();
                 out.write(result);
@@ -804,6 +830,29 @@
 
                 String payOrderNo = paymentCompetition.getPayOrderNo();
                 if (paymentCompetition.getPayType() == 1) {//微信支付
+                    if (StringUtils.hasLength(paymentCompetition.getFenzhangNo())){
+                        // 是分账订单 如果分账金额不为0 那么回退分账金额
+                        if (paymentCompetition.getFenzhangAmount()!=null && paymentCompetition.getFenzhangAmount().compareTo(BigDecimal.ZERO)>0){
+                            String randomCode = UUIDUtil.getRandomCode(16);
+                            String randomCode1 = UUIDUtil.getRandomCode(16);
+                            if (competition.getOperatorId()!=null && competition.getOperatorId()!=0){
+                                // 微信商户号
+                                String s2 =storeClient.getmerchantNumberByOperatorId(competition.getOperatorId());
+                                ResultUtil resultUtil = payMoneyUtil.fenzhangRefund(paymentCompetition.getFenzhangNo(), paymentCompetition.getFenzhangAmount(), s2, randomCode, randomCode1);
+                                if (!resultUtil.getCode().equals(200)){
+                                    System.err.println("分账回退失败 原因是:"+resultUtil.getMsg());
+                                }else{
+                                    paymentCompetition.setFenzhangRefundNo(resultUtil.getData().toString());
+                                    paymentCompetitionService.updateById(paymentCompetition);
+                                }
+
+                            }
+                        }
+                    }
+
+
+
+
                     Map<String, String> map = payMoneyUtil.wxRefund(payOrderNo, code, amount.toString(), amount.toString(),
                             "/base/competition/weChatCancelPaymentCompetitionCallback");
                     String return_code = map.get("return_code");

--
Gitblit v1.7.1