From b30e1a48f2bc5f65a0efd2e69e090fed2d7a627c Mon Sep 17 00:00:00 2001
From: yanghui <2536613402@qq.com>
Date: 星期四, 17 十一月 2022 15:56:43 +0800
Subject: [PATCH] #feat 订单退款和查询

---
 springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopFlowerRefundOrderServiceImpl.java |   59 +++++++++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 47 insertions(+), 12 deletions(-)

diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopFlowerRefundOrderServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopFlowerRefundOrderServiceImpl.java
index feeac7a..b6595b3 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopFlowerRefundOrderServiceImpl.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopFlowerRefundOrderServiceImpl.java
@@ -1,5 +1,6 @@
 package com.panzhihua.service_community.service.impl;
 
+import cn.hutool.core.collection.CollUtil;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
@@ -11,8 +12,10 @@
 import com.panzhihua.common.utlis.WxPayUtils;
 import com.panzhihua.common.utlis.wx.WXPayUtil;
 import com.panzhihua.service_community.dao.ComShopFlowerOrderDAO;
+import com.panzhihua.service_community.dao.ComShopFlowerOrderPayDAO;
 import com.panzhihua.service_community.dao.ComShopFlowerRefundOrderDAO;
 import com.panzhihua.service_community.model.dos.ComShopFlowerOrderDO;
+import com.panzhihua.service_community.model.dos.ComShopFlowerOrderPayDO;
 import com.panzhihua.service_community.model.dos.ComShopFlowerRefundOrderDO;
 import com.panzhihua.service_community.service.ComShopFlowerRefundOrderService;
 import lombok.extern.slf4j.Slf4j;
@@ -22,6 +25,7 @@
 
 import javax.annotation.Resource;
 import java.util.Date;
+import java.util.Map;
 import java.util.Objects;
 
 /**
@@ -35,19 +39,21 @@
 public class ComShopFlowerRefundOrderServiceImpl extends ServiceImpl<ComShopFlowerRefundOrderDAO, ComShopFlowerRefundOrderDO>
         implements ComShopFlowerRefundOrderService {
 
-    @Value("${hc_min.app.isTest}")
+    @Value("${hcMin.app.isTest}")
     private Boolean isTest;
-    @Value("${hc_min.app.appid}")
+    @Value("${hcMin.app.appid}")
     private String appid;
-    @Value("${hc_min.app.payKey}")
+    @Value("${hcMin.app.payKey}")
     private String payKey;
-    @Value("${hc_min.app.mchId}")
+    @Value("${hcMin.app.mchId}")
     private String mchId;
-    @Value("${hc_min.app.notifyUrl}")
+    @Value("${hcMin.app.notifyUrl}")
     private String notifyUrl;
 
     @Resource
     private ComShopFlowerOrderDAO comShopFlowerOrderDAO;
+    @Resource
+    private ComShopFlowerOrderPayDAO comShopFlowerOrderPayDAO;
 
 
     @Override
@@ -73,6 +79,7 @@
     @Override
     public R updateRefundOrder(ComShopFlowerRefundOrderDTO comShopFlowerRefundOrderDTO) {
         ComShopFlowerRefundOrderDO comShopFlowerRefundOrderDO = this.baseMapper.selectById(comShopFlowerRefundOrderDTO.getId());
+
         if (Objects.isNull(comShopFlowerRefundOrderDO)) {
             return R.fail("不存在该退款订单");
         }
@@ -80,19 +87,49 @@
             //处理退款事宜
             comShopFlowerRefundOrderDO.setRefundTime(new Date());
             comShopFlowerRefundOrderDO.setHandleTime(new Date());
-
+            comShopFlowerRefundOrderDO.setHandleResult(ComShopFlowerRefundOrderDO.handleResult.agree);
             //微信处理退款
             try {
                 String refundNo = WXPayUtil.generateNonceStr();
                 ComShopFlowerOrderDO comShopFlowerOrderDO = comShopFlowerOrderDAO.selectById(comShopFlowerRefundOrderDO.getOrderId());
                 String refundStr = WxPayUtils.refund(appid, mchId, comShopFlowerOrderDO.getWxTardeNo(), comShopFlowerRefundOrderDO.getPayAmount(),
                         comShopFlowerRefundOrderDO.getRefundAmount(), refundNo, isTest);
-                log.info(refundStr);
-                comShopFlowerRefundOrderDO.setStatus(ComShopFlowerRefundOrderDO.status.tkcg);
-                comShopFlowerRefundOrderDO.setHandleResult(ComShopFlowerRefundOrderDO.handleResult.agree);
+                log.info("退款请求接口返回参数:{}" , refundStr);
+                Map<String, String> mapResult  = WXPayUtil.xmlToMap(refundStr);
+                if (CollUtil.isNotEmpty(mapResult)) {
+                    String return_code = (String) mapResult.get("return_code");
+                    String result_code = (String) mapResult.get("result_code");
+                    String return_msg = mapResult.get("return_msg");
+                    ComShopFlowerOrderPayDO orderPayDO = new ComShopFlowerOrderPayDO();
 
+                    orderPayDO.setOrderNo(comShopFlowerOrderDO.getOrderNo());
+                    orderPayDO.setOrderAmount(comShopFlowerOrderDO.getTotalAmount());
+                    orderPayDO.setPayTime(new Date());
+                    orderPayDO.setStoreId(comShopFlowerOrderDO.getStoreId());
+                    orderPayDO.setDeliveryType(comShopFlowerOrderDO.getDeliveryType());
+                    orderPayDO.setOrderId(comShopFlowerOrderDO.getId());
+                    orderPayDO.setPayType(ComShopFlowerOrderPayDO.payType.tk);
+                    orderPayDO.setRefundOrderNo(comShopFlowerRefundOrderDO.getRefundOrderNo());
+                    orderPayDO.setPayAmount(comShopFlowerRefundOrderDO.getRefundAmount());
+                    if ("SUCCESS".equals(return_code) && return_code.equals(result_code)) {
+                        //退款成功
+                        comShopFlowerRefundOrderDO.setStatus(ComShopFlowerRefundOrderDO.status.tkcg);
+                        // 添加订单支付记录表
+//                        orderPayDO.setWxTradeNo(wxPayNotifyOrderDTO.getWxTradeNo());
+                        orderPayDO.setPayStatus(ComShopFlowerOrderPayDO.payStatus.yes);
+                        orderPayDO.setRefundStatus(ComShopFlowerOrderPayDO.refundStatus.tkcg);
+                    }else {
+                        //退款失败
+                        comShopFlowerRefundOrderDO.setStatus(ComShopFlowerRefundOrderDO.status.tksb);
+                        comShopFlowerRefundOrderDO.setRemark(comShopFlowerRefundOrderDO.getRemark() + "_"+return_msg);
+                        // 添加订单支付记录表
+                        orderPayDO.setPayStatus(ComShopFlowerOrderPayDO.payStatus.no);
+                        orderPayDO.setRefundStatus(ComShopFlowerOrderPayDO.refundStatus.tksb);
+                    }
+                    comShopFlowerOrderPayDAO.insert(orderPayDO);
+                }
             } catch (Exception e) {
-                log.error(e.getMessage());
+                log.error("申请退款失败,"+e.getMessage());
                 e.printStackTrace();
             }
 
@@ -101,9 +138,7 @@
             comShopFlowerRefundOrderDO.setStatus(ComShopFlowerRefundOrderDO.status.tksb);
             comShopFlowerRefundOrderDO.setHandleResult(ComShopFlowerRefundOrderDO.handleResult.refuse);
         }
-
         this.baseMapper.updateById(comShopFlowerRefundOrderDO);
-
         return R.ok();
     }
 }

--
Gitblit v1.7.1