From 6e8a55edef22faa7f7d5bbbccd727119a6fd918f Mon Sep 17 00:00:00 2001 From: rentaiming <806181062@qq.com> Date: 星期一, 03 六月 2024 14:05:08 +0800 Subject: [PATCH] 用户端商品 --- ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/PaylogServiceImpl.java | 96 ++++++++++++++++++++++++++--------------------- 1 files changed, 53 insertions(+), 43 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 6ed185d..95882ef 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 @@ -7,10 +7,13 @@ import com.alipay.api.DefaultAlipayClient; import com.alipay.api.request.AlipayTradeRefundRequest; import com.alipay.api.response.AlipayTradeRefundResponse; +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.ruoyi.common.core.constant.SecurityConstants; import com.ruoyi.common.core.domain.R; import com.ruoyi.common.core.utils.StringUtils; -import com.ruoyi.order.domain.pojo.Paylog; +import com.ruoyi.order.domain.Paylog; import com.ruoyi.order.mapper.PaylogMapper; import com.ruoyi.order.service.IPaylogService; import com.ruoyi.order.util.SinataUtil; @@ -21,7 +24,10 @@ 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.dto.BondDTO; import com.ruoyi.system.api.domain.dto.RefundDTO; +import com.ruoyi.system.api.feignClient.OrderClient; import java.io.IOException; import java.io.PrintWriter; import java.math.BigDecimal; @@ -31,7 +37,6 @@ import java.util.Iterator; import java.util.List; import java.util.Map; -import java.util.Objects; import java.util.Optional; import java.util.Set; import java.util.function.Function; @@ -41,6 +46,7 @@ import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; + import org.springframework.stereotype.Service; /** @@ -54,11 +60,10 @@ @Service public class PaylogServiceImpl extends ServiceImpl<PaylogMapper, Paylog> implements IPaylogService { - @Resource - private PaylogServiceImpl paylogServiceImpl; + @Resource - private IPaylogService iPaylogService; + private OrderClient orderClient; @Override public R<Map<String, Object>> getPayInfo(Integer uid, Integer type, String subject, String body, String orderNO,String openId, HttpServletRequest request) { @@ -72,10 +77,10 @@ Map<String, Object> map = new HashMap<String, Object>(); if (type == 1) { // 支付宝预下单 - return paylogServiceImpl.alipay(orderNO, subject, body, price, request); + return this.alipay(orderNO, subject, body, price, request); } else { // 微信预下单 - return paylogServiceImpl.wxpay(2, orderNO, body,openId, price, request); + return this.wxpay(2, orderNO, body,openId, price, request); } } } catch (Exception e) { @@ -114,19 +119,31 @@ params.put(name, valueStr); } - Paylog paylog = getPayLog_alipay(request); + Paylog paylog1= getPayLog_alipay(request); // 验证成功 - if ("TRADE_FINISHED".equals(paylog.getTradeStatus())) { + if ("TRADE_FINISHED".equals(paylog1.getTradeStatus())) { System.out.println("AlipayController.notifyUrl__验证成功:success"); // 支付失败 - } else if ("TRADE_SUCCESS".equals(paylog.getTradeStatus())) { + } else if ("TRADE_SUCCESS".equals(paylog1.getTradeStatus())) { // 支付成功 try { - if(judgeContainsStr(paylog.getOutTradeNo())){ + LambdaQueryWrapper<Paylog> wrapper = Wrappers.lambdaQuery(); + wrapper.eq(Paylog::getOutTradeNo,paylog1.getOutTradeNo()); + Paylog one = this.getOne(wrapper); + if(SinataUtil.isEmpty(one)) { + this.save(paylog1); + if (paylog1.getOutTradeNo().contains("BO")) { + BondDTO bondVO=new BondDTO(); + bondVO.setOrderNO(paylog1.getOutTradeNo()); + orderClient.UpdateBond(bondVO, SecurityConstants.INNER); + } } + + + // ——请根据您的业务逻辑来编写程序(以上代码仅作参考)—— log.debug("AlipayController.notifyUrl__回调处理:success"); out.println("success"); // 请不要修改或删除 @@ -196,17 +213,27 @@ ///////////////////////////// 这里程序处理支付回调逻辑 ///////////////////////////// //////////////////// - 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()); - iPaylogService.save(paylog); - if (judgeContainsStr(paylog.getOutTradeNo())) { + + 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")) { + BondDTO bondVO=new BondDTO(); + bondVO.setOrderNO(paylog.getOutTradeNo()); + orderClient.UpdateBond(bondVO, SecurityConstants.INNER); + + } log.debug("WxpayController.notify__回调处理成功:SUCCESS"); @@ -427,7 +454,6 @@ paylog.setState(1); paylog.setAddTime(LocalDateTime.now()); paylog.setTradeStatus(trade_status.toString()); - iPaylogService.save(paylog); return paylog; } @@ -443,7 +469,7 @@ Set<String> orderNoList = refundDTOS.stream().map(RefundDTO::getOrderNo) .collect(Collectors.toSet()); if (StringUtils.isNotEmpty(orderNoList)) { - Map<String, Paylog> paylogMap = iPaylogService.lambdaQuery() + Map<String, Paylog> paylogMap = this.lambdaQuery() .in(Paylog::getOutTradeNo, orderNoList).eq(Paylog::getState, 1).list().stream() .collect(Collectors.toMap(Paylog::getOutTradeNo, Function.identity())); List<Paylog> updList = new ArrayList<>(); @@ -460,25 +486,9 @@ } }); } - iPaylogService.updateBatchById(updList); + this.updateBatchById(updList); } return map; - } - - public static void main(String[] args) { - Map<String, Object> map = new HashMap<>(); - map.put("1", true); - map.put("2", false); - map.put("3", true); - map.put("4", false); - map.put("5", true); - List<String> collect = map.entrySet().stream().map(entry -> { - if (!(boolean) entry.getValue()) { - return entry.getKey(); - } - return null; - }).filter(Objects::nonNull).collect(Collectors.toList()); - System.out.println(collect); } private Boolean handleRefund(Paylog paylog, BigDecimal amount, @@ -486,7 +496,7 @@ boolean res = false; if (StringUtils.isNotNull(paylog)) { if (paylog.getPayType() == 1) { - res = paylogServiceImpl.refundForAlipay(paylog.getOutTradeNo(), + res = this.refundForAlipay(paylog.getOutTradeNo(), paylog.getTradeNo(), amount.doubleValue()); } if (paylog.getPayType() == 2) { @@ -497,7 +507,7 @@ String money = SinataUtil.doubleRetainTwo(paylog.getPayMoney() * 100d); Integer totalFee = Integer.parseInt( money.substring(0, money.length() - 3)); - res = paylogServiceImpl.refundForWxpay(2, paylog.getTradeNo(), + res = this.refundForWxpay(2, paylog.getTradeNo(), paylog.getOutTradeNo(), orderNo, totalFee, refundFee, "4"); } -- Gitblit v1.7.1