From 226045746b82227e2594e089539a48397dc7a24b Mon Sep 17 00:00:00 2001 From: rentaiming <806181062@qq.com> Date: 星期三, 31 七月 2024 19:36:20 +0800 Subject: [PATCH] 修改bug --- ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/PaylogServiceImpl.java | 430 ++++++++++++++++++++++------------------------------- 1 files changed, 178 insertions(+), 252 deletions(-) diff --git a/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/PaylogServiceImpl.java b/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/PaylogServiceImpl.java index a5c6bde..25a8d4f 100644 --- a/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/PaylogServiceImpl.java +++ b/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/PaylogServiceImpl.java @@ -1,8 +1,5 @@ package com.ruoyi.order.service.impl; -import static com.ruoyi.order.util.tencent.WXPay.requestRefundService; -import static com.ruoyi.order.util.tencent.WXPay.requestUnifiedorderService; - import com.alipay.api.AlipayClient; import com.alipay.api.DefaultAlipayClient; import com.alipay.api.request.AlipayTradeRefundRequest; @@ -18,37 +15,46 @@ import com.ruoyi.common.core.enums.OrderStatusEnum; import com.ruoyi.common.core.enums.PaymentMethodEnum; import com.ruoyi.common.core.enums.PointStatusEnum; -import com.ruoyi.common.core.exception.ServiceException; import com.ruoyi.common.core.utils.StringUtils; import com.ruoyi.order.domain.Paylog; import com.ruoyi.order.mapper.OrderAuctionBondMapper; import com.ruoyi.order.mapper.OrderMapper; import com.ruoyi.order.mapper.PaylogMapper; -import com.ruoyi.order.service.IOrderAuctionBondService; import com.ruoyi.order.service.IPaylogService; import com.ruoyi.order.util.MD5AndKL; import com.ruoyi.order.util.SinataUtil; import com.ruoyi.order.util.alipay.config.AlipayConfig; import com.ruoyi.order.util.alipay.util.PayDemoActivity; import com.ruoyi.order.util.tencent.common.Configure; -import com.ruoyi.order.util.tencent.common.Signature; import com.ruoyi.order.util.tencent.common.XMLParser; -import com.ruoyi.order.util.tencent.protocol.AppPayReqData; -import com.ruoyi.order.util.tencent.protocol.UnifiedorderReqData; -import com.ruoyi.system.api.domain.*; -import com.ruoyi.system.api.domain.dto.BondDTO; +import com.ruoyi.system.api.domain.GoodsGroupPurchase; +import com.ruoyi.system.api.domain.GoodsGroupPurchaseInfo; +import com.ruoyi.system.api.domain.GoodsSku; +import com.ruoyi.system.api.domain.Order; +import com.ruoyi.system.api.domain.OrderAuctionBond; import com.ruoyi.system.api.domain.dto.MemberPointsDTO; import com.ruoyi.system.api.domain.dto.RefundDTO; import com.ruoyi.system.api.domain.dto.updMembeOneDTO; import com.ruoyi.system.api.feignClient.AuctionClient; import com.ruoyi.system.api.feignClient.GoodsSkuClient; import com.ruoyi.system.api.feignClient.MemberClient; - -import java.io.*; +import java.io.IOException; +import java.io.PrintWriter; import java.math.BigDecimal; import java.time.LocalDateTime; -import java.time.format.DateTimeFormatter; -import java.util.*; +import java.util.ArrayList; +import java.util.Collections; +import java.util.Comparator; +import java.util.Date; +import java.util.HashMap; +import java.util.Iterator; +import java.util.List; +import java.util.Map; +import java.util.Optional; +import java.util.Set; +import java.util.SortedMap; +import java.util.TreeMap; +import java.util.UUID; import java.util.function.Function; import java.util.regex.Matcher; import java.util.regex.Pattern; @@ -56,10 +62,7 @@ import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; - -import com.ruoyi.system.api.feignClient.OrderClient; import org.springframework.stereotype.Service; -import org.springframework.util.Assert; /** * <p> @@ -108,7 +111,8 @@ one1.setPaymentMethod(PaymentMethodEnum.WECHAT); orderAuctionBondMapper.updateById(one1); - if (one1.getBond().compareTo(new BigDecimal(0))==0){ + + if (one1.getBond()==null||one1.getBond().compareTo(new BigDecimal(0))==0){ one1.setBoundStatus(BondStatusEnum.PAID); Map<String, Object> returnMap = new HashMap<>(); returnMap.put("Type",1); @@ -124,40 +128,11 @@ page1.setOrderStatus(OrderStatusEnum.TO_BE_SHIPPED); page1.setPaymentMethod(PaymentMethodEnum.WECHAT); page1.setPayTime(LocalDateTime.now()); - - - if(page1.getOrderNo().contains("SP")){ - GoodsSku goodsSku =new GoodsSku(); - goodsSku.setId(page1.getGoodsSkuId()); - goodsSku.setSoldQuantity(page1.getGoodsQuantity()); - goodsSkuClient.updGoods(goodsSku, SecurityConstants.INNER); - } - - if(page1.getOrderNo().contains("MS")){ - GoodsSku goodsSku =new GoodsSku(); - goodsSku.setId(page1.getGoodsSkuId()); - goodsSku.setSoldQuantity(page1.getGoodsQuantity()); - goodsSkuClient.updGoodsSeckill1(goodsSku, SecurityConstants.INNER); - } - - - if(page1.getOrderNo().contains("TG")){ - GoodsGroupPurchase goodsSeckiGoodsGroupPurchaseOne = goodsSkuClient.getGoodsSeckiGoodsGroupPurchaseOne(page1.getGoodsSkuId(), SecurityConstants.INNER).getData(); - GoodsGroupPurchaseInfo goodsSeckiGoodsGroupPurchaseInfo = goodsSkuClient.getGoodsSeckiGoodsGroupPurchaseInfo(page1.getGoodsSkuId(), SecurityConstants.INNER).getData(); - if (goodsSeckiGoodsGroupPurchaseInfo!=null){ - goodsSkuClient.updgoodsGroupPurchaseInfo(goodsSeckiGoodsGroupPurchaseInfo, SecurityConstants.INNER); - page1.setGroupNo(goodsSeckiGoodsGroupPurchaseInfo.getMubre()); - }else{ - UUID uuid = UUID.randomUUID(); - GoodsGroupPurchaseInfo goodsGroupPurchaseInfo=new GoodsGroupPurchaseInfo(); - goodsGroupPurchaseInfo.setGroupSize(goodsSeckiGoodsGroupPurchaseOne.getGroupSize()); - goodsGroupPurchaseInfo.setCurrentNumber(1); - goodsGroupPurchaseInfo.setMubre(uuid.toString()); - goodsGroupPurchaseInfo.setGroupPurchaseId(page1.getGoodsSkuId()); - goodsGroupPurchaseInfo.setGroupStatus(0); - goodsSkuClient.updgoodsGroupPurchaseInfo(goodsGroupPurchaseInfo, SecurityConstants.INNER); - page1.setGroupNo(uuid.toString()); - } + OrderMapper.updateById(page1); + if (page1.getTotalAmount().compareTo(new BigDecimal(0))==0){ + Map<String, Object> returnMap = new HashMap<>(); + returnMap.put("Type",1); + return R.ok(returnMap); } OrderMapper.updateById(page1); @@ -179,73 +154,6 @@ } - - /*if (orderNO.contains("BO")) { - LambdaQueryWrapper<OrderAuctionBond> wrapper1= Wrappers.lambdaQuery(); - wrapper1.eq(OrderAuctionBond::getOrderNo,orderNO); - wrapper1.eq(OrderAuctionBond::getDelFlag,0); - OrderAuctionBond one1 = orderAuctionBondMapper.selectOne(wrapper1); - if (one1.getBond().compareTo(new BigDecimal(0))==0){ - one1.setBoundStatus(BondStatusEnum.PAID); - Map<String, Object> returnMap = new HashMap<>(); - returnMap.put("Type",1); - return R.ok(returnMap); - } - - - }else{ - LambdaQueryWrapper<Order> wrapper1= Wrappers.lambdaQuery(); - wrapper1.eq(Order::getOrderNo,orderNO); - wrapper1.eq(Order::getDelFlag,0); - Order page1 = OrderMapper.selectOne(wrapper1); - if (page1.getTotalAmount().compareTo(new BigDecimal(0))==0){ - page1.setOrderStatus(OrderStatusEnum.TO_BE_SHIPPED); - page1.setPayTime(LocalDateTime.now()); - OrderMapper.updateById(page1); - Map<String, Object> returnMap = new HashMap<>(); - returnMap.put("Type",1); - - - page1.setOrderStatus(OrderStatusEnum.TO_BE_SHIPPED); - page1.setPayTime(LocalDateTime.now()); - OrderMapper.updateById(page1); - - if(page1.getOrderNo().contains("SP")){ - GoodsSku goodsSku =new GoodsSku(); - goodsSku.setId(page1.getGoodsSkuId()); - goodsSku.setSoldQuantity(page1.getGoodsQuantity()); - goodsSkuClient.updGoods(goodsSku, SecurityConstants.INNER); - } - - if(page1.getOrderNo().contains("MS")){ - GoodsSku goodsSku =new GoodsSku(); - goodsSku.setId(page1.getGoodsSkuId()); - goodsSku.setSoldQuantity(page1.getGoodsQuantity()); - goodsSkuClient.updGoodsSeckill1(goodsSku, SecurityConstants.INNER); - } - - - MemberPointsDTO memberPointsDTO=new MemberPointsDTO(); - memberPointsDTO.setMemberId(page1.getMemberId()); - memberPointsDTO.setPointsType(1); - memberPointsDTO.setPointsStatus(PointStatusEnum.INCREASE); - memberPointsDTO.setPoints(page1.getPoints()); - memberClient.addMemberPoints(memberPointsDTO); - - updMembeOneDTO MembeOneDTO=new updMembeOneDTO(); - MembeOneDTO.setType(1); - MembeOneDTO.setMemberId(page1.getMemberId()); - MembeOneDTO.setMoney(page1.getTotalAmount()); - MembeOneDTO.setTotalPoints(page1.getPoints()); - memberClient.updMembeOne(MembeOneDTO, SecurityConstants.INNER); - - - return R.ok(returnMap); - } - - - - }*/ if (orderNO.contains("BO")) { LambdaQueryWrapper<OrderAuctionBond> wrapper1= Wrappers.lambdaQuery(); @@ -352,6 +260,9 @@ wrapper1.eq(Order::getOrderNo,paylog1.getOutTradeNo()); wrapper1.eq(Order::getDelFlag,0); Order page1 = OrderMapper.selectOne(wrapper1); + + page1.setOrderStatus(OrderStatusEnum.TO_BE_SHIPPED); + page1.setPayTime(LocalDateTime.now()); if(page1.getOrderNo().contains("SP")){ GoodsSku goodsSku =new GoodsSku(); goodsSku.setId(page1.getGoodsSkuId()); @@ -370,31 +281,35 @@ GoodsGroupPurchase goodsSeckiGoodsGroupPurchaseOne = goodsSkuClient.getGoodsSeckiGoodsGroupPurchaseOne(page1.getGoodsSkuId(), SecurityConstants.INNER).getData(); GoodsGroupPurchaseInfo goodsSeckiGoodsGroupPurchaseInfo = goodsSkuClient.getGoodsSeckiGoodsGroupPurchaseInfo(page1.getGoodsSkuId(), SecurityConstants.INNER).getData(); if (goodsSeckiGoodsGroupPurchaseInfo!=null){ - goodsSkuClient.updgoodsGroupPurchaseInfo(goodsSeckiGoodsGroupPurchaseInfo, SecurityConstants.INNER); page1.setGroupNo(goodsSeckiGoodsGroupPurchaseInfo.getMubre()); + OrderMapper.updateById(page1); + Integer i= goodsSeckiGoodsGroupPurchaseInfo.getPurchaseNum()+page1.getGoodsQuantity(); + goodsSeckiGoodsGroupPurchaseInfo.setPurchaseNum(i); + goodsSkuClient.updgoodsGroupPurchaseInfo(goodsSeckiGoodsGroupPurchaseInfo, SecurityConstants.INNER); + }else{ UUID uuid = UUID.randomUUID(); + page1.setGroupNo(uuid.toString()); + OrderMapper.updateById(page1); GoodsGroupPurchaseInfo goodsGroupPurchaseInfo=new GoodsGroupPurchaseInfo(); goodsGroupPurchaseInfo.setGroupSize(goodsSeckiGoodsGroupPurchaseOne.getGroupSize()); goodsGroupPurchaseInfo.setCurrentNumber(1); + goodsGroupPurchaseInfo.setPurchaseNum(page1.getGoodsQuantity()); goodsGroupPurchaseInfo.setMubre(uuid.toString()); - goodsGroupPurchaseInfo.setGroupPurchaseId(page1.getGoodsSkuId()); + goodsGroupPurchaseInfo.setGroupPurchaseId(goodsSeckiGoodsGroupPurchaseOne.getId()); goodsGroupPurchaseInfo.setGroupStatus(0); goodsSkuClient.updgoodsGroupPurchaseInfo(goodsGroupPurchaseInfo, SecurityConstants.INNER); - page1.setGroupNo(uuid.toString()); + } } - page1.setOrderStatus(OrderStatusEnum.TO_BE_SHIPPED); - page1.setPayTime(LocalDateTime.now()); - OrderMapper.updateById(page1); if (page1.getPoints()!=0){ - MemberPointsDTO memberPointsDTO=new MemberPointsDTO(); - memberPointsDTO.setMemberId(page1.getMemberId()); - memberPointsDTO.setPointsType(1); - memberPointsDTO.setPointsStatus(PointStatusEnum.INCREASE); - memberPointsDTO.setPoints(page1.getPoints()); - memberClient.addMemberPoints(memberPointsDTO); + MemberPointsDTO memberPointsDTO=new MemberPointsDTO(); + memberPointsDTO.setMemberId(page1.getMemberId()); + memberPointsDTO.setPointsType(1); + memberPointsDTO.setPointsStatus(PointStatusEnum.INCREASE); + memberPointsDTO.setPoints(page1.getPoints()); + memberClient.addMemberPoints(memberPointsDTO); } updMembeOneDTO MembeOneDTO=new updMembeOneDTO(); MembeOneDTO.setType(1); @@ -405,8 +320,6 @@ } } - - // ——请根据您的业务逻辑来编写程序(以上代码仅作参考)—— log.debug("AlipayController.notifyUrl__回调处理:success"); @@ -455,129 +368,137 @@ System.out.println("WxpayController.notify__notityXml:\n" + notityXml); // 验证签名 - Map<String, Object> map = XMLParser.getMapFromXML(notityXml.toString()); - // log.debug("WxpayController.notify__map:\n" + map); - // 接口返回状态 - String result_code = (String) map.get("result_code"); - if ("SUCCESS".equals(result_code)) { - // // 商户订单号 - String out_trade_no = (String) map.get("out_trade_no"); - // // 微信支付交易号 - String trade_no = (String) map.get("transaction_id"); - // // 金额,以分为单位 - String total_fee = (String) map.get("total_fee"); - // // 优惠金额 - // String discount = (String) map.get("discount"); - // // 支付完成时间 - String time_end = (String) map.get("time_end"); - // // 支付者唯一Id(对应买家账号的一个加密串 ) - String buyer_id = (String) map.get("buyer_id"); + Map<String, Object> map = XMLParser.getMapFromXML(notityXml.toString()); + // log.debug("WxpayController.notify__map:\n" + map); + // 接口返回状态 + String result_code = (String) map.get("result_code"); + if ("SUCCESS".equals(result_code)) { + // // 商户订单号 + String out_trade_no = (String) map.get("out_trade_no"); + // // 微信支付交易号 + String trade_no = (String) map.get("transaction_id"); + // // 金额,以分为单位 + String total_fee = (String) map.get("total_fee"); + // // 优惠金额 + // String discount = (String) map.get("discount"); + // // 支付完成时间 + String time_end = (String) map.get("time_end"); + // // 支付者唯一Id(对应买家账号的一个加密串 ) + String buyer_id = (String) map.get("buyer_id"); - ///////////////////////////// 这里程序处理支付回调逻辑 - ///////////////////////////// //////////////////// + ///////////////////////////// 这里程序处理支付回调逻辑 + ///////////////////////////// //////////////////// - LambdaQueryWrapper<Paylog> wrapper = Wrappers.lambdaQuery(); - wrapper.eq(Paylog::getOutTradeNo,out_trade_no); - Paylog one = this.getOne(wrapper); - if(SinataUtil.isEmpty(one)) { - Paylog paylog = new Paylog(); - paylog.setOutTradeNo(out_trade_no); - paylog.setPayType(2); - paylog.setBuyerId(buyer_id); - paylog.setTradeNo(trade_no); - paylog.setPayMoney(Double.parseDouble(total_fee) / 100); - paylog.setState(1); - System.out.println("支付完成时间" + time_end); - paylog.setAddTime(LocalDateTime.now()); - this.save(paylog); - if (paylog.getOutTradeNo().contains("BO")) { - LambdaQueryWrapper<OrderAuctionBond> wrapper1= Wrappers.lambdaQuery(); - wrapper1.eq(OrderAuctionBond::getOrderNo,paylog.getOutTradeNo()); - wrapper1.eq(OrderAuctionBond::getDelFlag,0); - OrderAuctionBond one1 = orderAuctionBondMapper.selectOne(wrapper1); - if (one1.getOrderTimeSx().isAfter(LocalDateTime.now())){ - String refundMoney = SinataUtil.doubleRetainTwo(paylog.getPayMoney() * 100d); - Integer refundFee = Integer.parseInt(refundMoney.substring(0, refundMoney.length() - 3)); - String money = SinataUtil.doubleRetainTwo(paylog.getPayMoney() * 100d); - Integer totalFee = Integer.parseInt(money.substring(0, money.length() - 3)); - refundFee = Integer.parseInt(money.substring(0, money.length() - 3)); + LambdaQueryWrapper<Paylog> wrapper = Wrappers.lambdaQuery(); + wrapper.eq(Paylog::getOutTradeNo,out_trade_no); + Paylog one = this.getOne(wrapper); + if(SinataUtil.isEmpty(one)) { + Paylog paylog = new Paylog(); + paylog.setOutTradeNo(out_trade_no); + paylog.setPayType(2); + paylog.setBuyerId(buyer_id); + paylog.setTradeNo(trade_no); + paylog.setPayMoney(Double.parseDouble(total_fee) / 100); + paylog.setState(1); + System.out.println("支付完成时间" + time_end); + paylog.setAddTime(LocalDateTime.now()); + this.save(paylog); + if (paylog.getOutTradeNo().contains("BO")) { + LambdaQueryWrapper<OrderAuctionBond> wrapper1= Wrappers.lambdaQuery(); + wrapper1.eq(OrderAuctionBond::getOrderNo,paylog.getOutTradeNo()); + wrapper1.eq(OrderAuctionBond::getDelFlag,0); + OrderAuctionBond one1 = orderAuctionBondMapper.selectOne(wrapper1); + if (one1.getOrderTimeSx().isAfter(LocalDateTime.now())){ + String refundMoney = SinataUtil.doubleRetainTwo(paylog.getPayMoney() * 100d); + Integer refundFee = Integer.parseInt(refundMoney.substring(0, refundMoney.length() - 3)); + String money = SinataUtil.doubleRetainTwo(paylog.getPayMoney() * 100d); + Integer totalFee = Integer.parseInt(money.substring(0, money.length() - 3)); + refundFee = Integer.parseInt(money.substring(0, money.length() - 3)); - String regEx = "[^0-9]"; - Pattern p = Pattern.compile(regEx); - Matcher m = p.matcher(paylog.getOutTradeNo()); - String ma = m.replaceAll("").trim(); - refundForWxpay(4, paylog.getTradeNo(), paylog.getOutTradeNo(), "R" + ma, totalFee, refundFee, "2"); + String regEx = "[^0-9]"; + Pattern p = Pattern.compile(regEx); + Matcher m = p.matcher(paylog.getOutTradeNo()); + String ma = m.replaceAll("").trim(); + refundForWxpay(4, paylog.getTradeNo(), paylog.getOutTradeNo(), "R" + ma, totalFee, refundFee, "2"); + } + + one1.setBoundStatus(BondStatusEnum.PAID); + one1.setPaymentMethod(PaymentMethodEnum.WECHAT); + orderAuctionBondMapper.updateById(one1); + + }else{ + LambdaQueryWrapper<Order> wrapper1= Wrappers.lambdaQuery(); + wrapper1.eq(Order::getOrderNo,paylog.getOutTradeNo()); + wrapper1.eq(Order::getDelFlag,0); + Order page1 = OrderMapper.selectOne(wrapper1); + page1.setOrderStatus(OrderStatusEnum.TO_BE_SHIPPED); + page1.setPaymentMethod(PaymentMethodEnum.WECHAT); + page1.setPayTime(LocalDateTime.now()); + + + if(page1.getOrderNo().contains("SP")){ + GoodsSku goodsSku =new GoodsSku(); + goodsSku.setId(page1.getGoodsSkuId()); + goodsSku.setSoldQuantity(page1.getGoodsQuantity()); + goodsSkuClient.updGoods(goodsSku, SecurityConstants.INNER); + } + + if(page1.getOrderNo().contains("MS")){ + GoodsSku goodsSku =new GoodsSku(); + goodsSku.setId(page1.getGoodsSkuId()); + goodsSku.setSoldQuantity(page1.getGoodsQuantity()); + goodsSkuClient.updGoodsSeckill1(goodsSku, SecurityConstants.INNER); + } + if(page1.getOrderNo().contains("TG")){ + GoodsGroupPurchase goodsSeckiGoodsGroupPurchaseOne = goodsSkuClient.getGoodsSeckiGoodsGroupPurchaseOne(page1.getGoodsSkuId(), SecurityConstants.INNER).getData(); + GoodsGroupPurchaseInfo goodsSeckiGoodsGroupPurchaseInfo = goodsSkuClient.getGoodsSeckiGoodsGroupPurchaseInfo(page1.getGoodsSkuId(), SecurityConstants.INNER).getData(); + if (goodsSeckiGoodsGroupPurchaseInfo!=null){ + page1.setGroupNo(goodsSeckiGoodsGroupPurchaseInfo.getMubre()); + OrderMapper.updateById(page1); + Integer i= goodsSeckiGoodsGroupPurchaseInfo.getPurchaseNum()+page1.getGoodsQuantity(); + goodsSeckiGoodsGroupPurchaseInfo.setPurchaseNum(i); + goodsSkuClient.updgoodsGroupPurchaseInfo(goodsSeckiGoodsGroupPurchaseInfo, SecurityConstants.INNER); + + }else{ + UUID uuid = UUID.randomUUID(); + page1.setGroupNo(uuid.toString()); + OrderMapper.updateById(page1); + GoodsGroupPurchaseInfo goodsGroupPurchaseInfo=new GoodsGroupPurchaseInfo(); + goodsGroupPurchaseInfo.setGroupSize(goodsSeckiGoodsGroupPurchaseOne.getGroupSize()); + goodsGroupPurchaseInfo.setCurrentNumber(1); + goodsGroupPurchaseInfo.setPurchaseNum(page1.getGoodsQuantity()); + goodsGroupPurchaseInfo.setMubre(uuid.toString()); + goodsGroupPurchaseInfo.setGroupPurchaseId(goodsSeckiGoodsGroupPurchaseOne.getId()); + goodsGroupPurchaseInfo.setGroupStatus(0); + goodsSkuClient.updgoodsGroupPurchaseInfo(goodsGroupPurchaseInfo, SecurityConstants.INNER); + } - - one1.setBoundStatus(BondStatusEnum.PAID); - one1.setPaymentMethod(PaymentMethodEnum.WECHAT); - orderAuctionBondMapper.updateById(one1); - - }else{ - LambdaQueryWrapper<Order> wrapper1= Wrappers.lambdaQuery(); - wrapper1.eq(Order::getOrderNo,paylog.getOutTradeNo()); - wrapper1.eq(Order::getDelFlag,0); - Order page1 = OrderMapper.selectOne(wrapper1); - page1.setOrderStatus(OrderStatusEnum.TO_BE_SHIPPED); - page1.setPaymentMethod(PaymentMethodEnum.WECHAT); - page1.setPayTime(LocalDateTime.now()); - OrderMapper.updateById(page1); - - if(page1.getOrderNo().contains("SP")){ - GoodsSku goodsSku =new GoodsSku(); - goodsSku.setId(page1.getGoodsSkuId()); - goodsSku.setSoldQuantity(page1.getGoodsQuantity()); - goodsSkuClient.updGoods(goodsSku, SecurityConstants.INNER); - } - - if(page1.getOrderNo().contains("MS")){ - GoodsSku goodsSku =new GoodsSku(); - goodsSku.setId(page1.getGoodsSkuId()); - goodsSku.setSoldQuantity(page1.getGoodsQuantity()); - goodsSkuClient.updGoodsSeckill1(goodsSku, SecurityConstants.INNER); - } - if(page1.getOrderNo().contains("TG")){ - GoodsGroupPurchase goodsSeckiGoodsGroupPurchaseOne = goodsSkuClient.getGoodsSeckiGoodsGroupPurchaseOne(page1.getGoodsSkuId(), SecurityConstants.INNER).getData(); - GoodsGroupPurchaseInfo goodsSeckiGoodsGroupPurchaseInfo = goodsSkuClient.getGoodsSeckiGoodsGroupPurchaseInfo(page1.getGoodsSkuId(), SecurityConstants.INNER).getData(); - if (goodsSeckiGoodsGroupPurchaseInfo!=null){ - goodsSkuClient.updgoodsGroupPurchaseInfo(goodsSeckiGoodsGroupPurchaseInfo, SecurityConstants.INNER); - page1.setGroupNo(goodsSeckiGoodsGroupPurchaseInfo.getMubre()); - }else{ - UUID uuid = UUID.randomUUID(); - GoodsGroupPurchaseInfo goodsGroupPurchaseInfo=new GoodsGroupPurchaseInfo(); - goodsGroupPurchaseInfo.setGroupSize(goodsSeckiGoodsGroupPurchaseOne.getGroupSize()); - goodsGroupPurchaseInfo.setCurrentNumber(1); - goodsGroupPurchaseInfo.setMubre(uuid.toString()); - goodsGroupPurchaseInfo.setGroupStatus(0); - goodsSkuClient.updgoodsGroupPurchaseInfo(goodsGroupPurchaseInfo, SecurityConstants.INNER); - page1.setGroupNo(uuid.toString()); - } - } - if (page1.getPoints()!=0){ + } + if (page1.getPoints()!=0){ MemberPointsDTO memberPointsDTO=new MemberPointsDTO(); memberPointsDTO.setMemberId(page1.getMemberId()); memberPointsDTO.setPointsType(1); memberPointsDTO.setPointsStatus(PointStatusEnum.INCREASE); memberPointsDTO.setPoints(page1.getPoints()); memberClient.addMemberPoints(memberPointsDTO); - } - updMembeOneDTO MembeOneDTO=new updMembeOneDTO(); - MembeOneDTO.setType(1); - MembeOneDTO.setMemberId(page1.getMemberId()); - MembeOneDTO.setMoney(page1.getTotalAmount()); - MembeOneDTO.setTotalPoints(page1.getPoints()); - memberClient.updMembeOne(MembeOneDTO, SecurityConstants.INNER); } - - log.debug("WxpayController.notify__回调处理成功:SUCCESS"); - response.getOutputStream().print("success"); + updMembeOneDTO MembeOneDTO=new updMembeOneDTO(); + MembeOneDTO.setType(1); + MembeOneDTO.setMemberId(page1.getMemberId()); + MembeOneDTO.setMoney(page1.getTotalAmount()); + MembeOneDTO.setTotalPoints(page1.getPoints()); + memberClient.updMembeOne(MembeOneDTO, SecurityConstants.INNER); } + log.debug("WxpayController.notify__回调处理成功:SUCCESS"); response.getOutputStream().print("success"); - } else { - log.debug("WxpayController.notify__回调处理:验证状态错误!" + result_code); - System.out.println("验证状态错误!" + result_code); } + log.debug("WxpayController.notify__回调处理成功:SUCCESS"); + response.getOutputStream().print("success"); + } else { + log.debug("WxpayController.notify__回调处理:验证状态错误!" + result_code); + System.out.println("验证状态错误!" + result_code); + } } catch (Exception e) { e.printStackTrace(); @@ -706,7 +627,7 @@ //设置请求参数(总金额) String money=SinataUtil.doubleRetainTwo(price*100d); - Integer price1 = Integer.parseInt(money.substring(0,money.length()-3)); + Integer price1 = Integer.parseInt(money.substring(0,money.length()-3)); paraMap.put("total_fee", price1.toString()); //设置请求参数(通知地址) paraMap.put("notify_url", Configure.wx_notify_url); @@ -725,7 +646,7 @@ Map<String, String> map = PaymentKit.xmlToMap(xmlResult); //返回状态码 String returnCode = map.get("return_code"); - /* Assert.isTrue("SUCCESS".equals(returnCode), getMsgByCode(returnCode));*/ + /* Assert.isTrue("SUCCESS".equals(returnCode), getMsgByCode(returnCode));*/ //返回给小程序端需要的参数 Map<String, Object> returnMap = new HashMap<>(20); @@ -760,6 +681,7 @@ List<Map.Entry<String, Object>> infoIds = new ArrayList<Map.Entry<String, Object>>(entries); // 对所有传入参数按照字段名的 ASCII 码从小到大排序(字典序) Collections.sort(infoIds, new Comparator<Map.Entry<String, Object>>() { + @Override public int compare(Map.Entry<String, Object> o1, Map.Entry<String, Object> o2) { return (o1.getKey()).toString().compareTo(o2.getKey()); } @@ -873,12 +795,16 @@ return paylog; } - public boolean judgeContainsStr(String cardNum) { - String regex=".*[a-zA-Z]+.*"; - Matcher m= Pattern.compile(regex).matcher(cardNum); - return m.matches(); - } + public boolean judgeContainsStr(String cardNum) { + String regex=".*[a-zA-Z]+.*"; + Matcher m= Pattern.compile(regex).matcher(cardNum); + return m.matches(); + } + /** + * @param refundDTOS 退款数据传输对象 + * @return Map<String, Object> key :orderNo value 退款结果 + */ @Override public Map<String, Object> refund(List<RefundDTO> refundDTOS) { Map<String, Object> map = new HashMap<>(); @@ -948,11 +874,11 @@ } private Boolean handleRefund(Paylog paylog, BigDecimal amount, - String orderNo) { + String orderNo) { boolean res = false; if (StringUtils.isNotNull(paylog)) { if (paylog.getPayType() == 1) { - res = this.refundForAlipay(paylog.getOutTradeNo(), + res = refundForAlipay(paylog.getOutTradeNo(), paylog.getTradeNo(), amount.doubleValue()); } if (paylog.getPayType() == 2) { @@ -963,9 +889,9 @@ String money = SinataUtil.doubleRetainTwo(paylog.getPayMoney() * 100d); Integer totalFee = Integer.parseInt( money.substring(0, money.length() - 3)); - res = this.refundForWxpay(2, paylog.getTradeNo(), + res = refundForWxpay(1, paylog.getTradeNo(), paylog.getOutTradeNo(), orderNo, totalFee, - refundFee, "4"); + refundFee, "2"); } } return res; -- Gitblit v1.7.1