From 1a66508ad3d73dcc456162c553b03f2208570b51 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Wed, 31 Aug 2022 16:15:54 +0800
Subject: [PATCH] 20220822

---
 src/main/java/cc/mrbird/febs/pay/controller/XcxPayController.java |  107 +++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 107 insertions(+), 0 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/pay/controller/XcxPayController.java b/src/main/java/cc/mrbird/febs/pay/controller/XcxPayController.java
index 3a74c5e..93b09e9 100644
--- a/src/main/java/cc/mrbird/febs/pay/controller/XcxPayController.java
+++ b/src/main/java/cc/mrbird/febs/pay/controller/XcxPayController.java
@@ -6,8 +6,13 @@
 import cc.mrbird.febs.common.properties.XcxProperties;
 import cc.mrbird.febs.common.utils.RedisUtils;
 import cc.mrbird.febs.common.utils.SpringContextHolder;
+import cc.mrbird.febs.mall.entity.MallMemberWallet;
+import cc.mrbird.febs.mall.entity.MallMoneyFlow;
 import cc.mrbird.febs.mall.entity.MallOrderInfo;
+import cc.mrbird.febs.mall.mapper.MallMemberWalletMapper;
+import cc.mrbird.febs.mall.mapper.MallMoneyFlowMapper;
 import cc.mrbird.febs.mall.mapper.MallOrderInfoMapper;
+import cc.mrbird.febs.mall.service.IApiMallMemberWalletService;
 import cc.mrbird.febs.pay.model.NotifyData;
 import cc.mrbird.febs.pay.model.OrderStateDto;
 import cc.mrbird.febs.pay.model.OrderStateMsgVo;
@@ -18,6 +23,9 @@
 import cc.mrbird.febs.pay.util.Signature;
 import cc.mrbird.febs.pay.util.Util;
 import cc.mrbird.febs.pay.util.WechatConfigure;
+import cn.hutool.core.util.ObjectUtil;
+import cn.hutool.json.JSONObject;
+import cn.hutool.json.JSONUtil;
 import io.swagger.annotations.ApiOperation;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.BeanUtils;
@@ -48,13 +56,112 @@
     @Autowired
     MallOrderInfoMapper mallOrderInfoMapper;
     @Autowired
+    MallMoneyFlowMapper mallMoneyFlowMapper;
+    @Autowired
+    MallMemberWalletMapper mallMemberWalletMapper;
+    @Autowired
     RedisUtils redisUtils;
+    @Autowired
+    private IApiMallMemberWalletService memberWalletService;
 
     @Autowired
     private IXcxPayService iXcxPayService;
 
     private final XcxProperties xcxProperties = SpringContextHolder.getBean(XcxProperties.class);
     /**
+     * 微信充值回调接口
+     */
+    @Transactional(rollbackFor = Exception.class)
+    @RequestMapping(value = "/rechargeCallBack")
+    public void rechargeCallBack(HttpServletResponse response, HttpServletRequest request) throws IOException {
+        log.info("微信充值回调start....");
+
+        // 获取输入参数
+        String inputLine;
+        StringBuffer notityXml = new StringBuffer();
+        String resXml = "";
+
+//        String attrStr = "{'rechargeNo':"+rechargeNo+",'memberId':"+mallMember.getId()+"}";
+        String attrStr = "";
+
+        FebsResponse threadResult = new FebsResponse();
+        try {
+            while ((inputLine = request.getReader().readLine()) != null) {
+                notityXml.append(inputLine);
+            }
+            request.getReader().close();
+            log.info("notityXml ---- :{} ", notityXml);
+
+
+            // XMl转对象
+            Object bb = Util.getObjectFromXML(notityXml.toString(), NotifyData.class);
+            NotifyData data = new NotifyData();
+            BeanUtils.copyProperties(bb,data);
+            log.info("----return_code = {}", data.getReturn_code());
+            // 返回状态码 SUCCESS/FAIL
+            if (WechatConfigure.CODE_SUCCESS.equals(data.getReturn_code())) {
+                attrStr = data.getAttach();
+                JSONObject jsonObject = JSONUtil.parseObj(attrStr);
+                String rechargeNo = (String) jsonObject.get("rechargeNo");
+                Long memberId = (Long) jsonObject.get("memberId");
+                // 检验订单状态
+                MallMoneyFlow mallMoneyFlow = mallMoneyFlowMapper.selectOneByOrderNoAndMemberId(rechargeNo,memberId);
+                // 校验签名
+//                String paySecret = WechatConfigure.WECHARPAY_SECRET;
+                String paySecret = xcxProperties.getWecharpaySecret();
+                if (Signature.checkIsSignValidFromResponseString(notityXml.toString(),paySecret)) {
+                    // 校验业务结果
+                    if (WechatConfigure.CODE_SUCCESS.equals(data.getResult_code())) {
+                        // 返回SUCCESS报文
+                        resXml = WechatConfigure.RESULT_XML_SUCCESS;
+                        // 支付费用
+                        Double total_fee = Double.parseDouble(data.getTotal_fee());
+                        // 商户订单号
+                        String payNum = data.getOut_trade_no();
+
+                        log.info("支付回调关键信息---total_fee:{},payNum:{},rechargeNo:{}", total_fee, payNum, rechargeNo);
+                        // 订单ID
+                        BigDecimal payMoney = new BigDecimal(total_fee).divide(new BigDecimal(100), 2,
+                                RoundingMode.HALF_UP);
+
+                        if (ObjectUtil.isNotEmpty(mallMoneyFlow)) {
+                            log.debug("检查支付金额payMoney={},mallMoneyFlow.getPayMoney()={}", payMoney, mallMoneyFlow.getAmount());
+                            MallMemberWallet mallMemberWallet = mallMemberWalletMapper.selectWalletByMemberId(memberId);
+                            if(ObjectUtil.isNotEmpty(mallMemberWallet)){
+                                memberWalletService.addBalance(payMoney,memberId);
+                            }
+                            threadResult.success().message("充值成功");
+                        } else {
+                            log.info("充值失败", attrStr);
+                        }
+                    } else {
+                        log.info("微信标识业务是失败");
+                        threadResult.fail().message("查询支付信息失败,请联系客服或者刷新支付信息(错误码:001)");
+//                        resXml = AppConstance.RESULT_XML_FAIL.replace(ERRORMSG, "微信标识业务是失败");
+                    }
+                } else {
+                    log.info("无效签名");
+                    threadResult.fail().message("查询支付信息失败,请联系客服或者刷新支付信息(错误码:002)");
+//                    resXml = AppConstance.RESULT_XML_FAIL.replace(ERRORMSG, "微信标识业务是失败");
+                }
+            } else {
+                log.info("通信标识失败");
+                threadResult.fail().message("查询支付信息失败,请联系客服或者刷新支付信息(错误码:003)");
+//                resXml = AppConstance.RESULT_XML_FAIL.replace(ERRORMSG, "通信标识失败");
+            }
+        } catch (Exception e) {
+            log.error("支付回调签名错误", e);
+            threadResult.fail().message("查询支付信息失败,请联系客服或者刷新支付信息(错误码:004)");
+//            resXml = AppConstance.RESULT_XML_FAIL.replace(ERRORMSG, "支付回调签名错误");
+        } finally {
+            // 通知线程消息
+//            PayThreadPool.notifyThread(Integer.valueOf(orderId), threadResult);
+            sendResultBack(response, resXml);
+        }
+        return;
+
+    }
+    /**
      * 微信支付回调接口
      */
     @Transactional(rollbackFor = Exception.class)

--
Gitblit v1.9.1