From 13cbf3a947c6a26f11cd74806d3faee2590c469e Mon Sep 17 00:00:00 2001 From: admin <weikou2014> Date: 星期二, 25 五月 2021 19:05:53 +0800 Subject: [PATCH] Merge branch 'master' of ssh://193.112.35.168:29418/tejia --- service-vip/src/main/java/com/ks/vip/service/remote/VipOrderPayServiceImpl.java | 222 ++++++++++++++++++++++++++++++++++++------------------ 1 files changed, 147 insertions(+), 75 deletions(-) diff --git a/service-vip/src/main/java/com/ks/vip/service/remote/VipOrderPayServiceImpl.java b/service-vip/src/main/java/com/ks/vip/service/remote/VipOrderPayServiceImpl.java index 872e011..2dee4f3 100644 --- a/service-vip/src/main/java/com/ks/vip/service/remote/VipOrderPayServiceImpl.java +++ b/service-vip/src/main/java/com/ks/vip/service/remote/VipOrderPayServiceImpl.java @@ -1,5 +1,7 @@ package com.ks.vip.service.remote; +import com.alipay.api.AlipayApiException; +import com.alipay.api.response.AlipayTradeQueryResponse; import com.ks.vip.exception.VipOrderException; import com.ks.vip.mapper.VipOrderMapper; import com.ks.vip.pojo.DO.VipCombo; @@ -7,12 +9,13 @@ import com.ks.vip.pojo.DTO.PayWayInfoDTO; import com.ks.vip.pojo.DTO.VipOrderDTO; import com.ks.vip.pojo.Enums.OrderTypeEnum; -import com.ks.vip.query.VipOrderQuery; +import com.ks.vip.pojo.Enums.PayWayEnum; import com.ks.vip.service.VipCenterService; import com.ks.vip.service.VipComboService; import com.ks.vip.service.VipOrederPayService; -import com.ks.vip.service.VipOrederService; +import com.ks.vip.service.manager.RedisManager; import com.ks.vip.util.Constant; +import com.ks.vip.util.PayUtil; import org.apache.dubbo.config.annotation.Service; import org.springframework.transaction.annotation.Transactional; import org.yeshi.utils.StringUtil; @@ -21,10 +24,7 @@ import org.yeshi.utils.wx.WXPayV3Util; import javax.annotation.Resource; -import java.math.BigDecimal; -import java.math.RoundingMode; import java.util.Date; -import java.util.List; import java.util.UUID; @Service(version = "1.0") @@ -39,89 +39,161 @@ @Resource private VipCenterService vipCenterService; + @Resource + private RedisManager redisManager; - - @Transactional(rollbackFor = Exception.class) @Override - public PayWayInfoDTO payOrder(OrderRecord record) throws OrderException, GoldCornException, PayException, VIPException, PPTVException, VideoBuyRecordException { - String orderNo = VIPOrderUtil.getOutOrderNo(record.getOrderType(), record.getId()); - switch (record.getPayWay()) { - case OrderRecord.PAY_WAY_ALIPAY_GOLDCORN: - try { - goldCornManager.consumeGoldCorn(record, record.getGoldCorn()); - } catch (Exception e) { - throw new GoldCornException(1, "褰辫璞嗘墸闄ゅ嚭閿�"); - } - paySuccess(record.getId(), OrderRecord.PAY_WAY_GOLDCORN, null, new Date()); + @Transactional(rollbackFor = Exception.class) + public PayWayInfoDTO addOrderByBuy(VipOrderDTO t) throws VipOrderException { + if (t.getComboId() == null || t.getComboId() <= 0) { + throw new VipOrderException(1, "濂楅ID涓嶈兘涓虹┖"); + } + if (StringUtil.isNullOrEmpty(t.getUid())) { + throw new VipOrderException(1, "鐢ㄦ埛ID涓嶈兘涓虹┖"); + } + if (t.getPayWay() == null) { + throw new VipOrderException(1, "浠樻鏂瑰紡涓嶈兘涓虹┖"); + } + if (StringUtil.isNullOrEmpty(t.getThreeOrderId())) { + throw new VipOrderException(1, "浠樻璁㈠崟鍙蜂笉鑳戒负绌�"); + } - orderLogger.info("璁㈠崟褰辫璞嗘敮浠樻垚鍔燂細id-{}", record.getId()); - case OrderRecord.PAY_WAY_ALIPAY: { - if (record.getMoney() != null && record.getMoney().compareTo(new BigDecimal(0)) == 0) { - return new PayWayInfoDTO(0, VipUtil.getPaySuccessUrl(record.getId())); + // 妫�鏌ユ槸鍚﹀凡璁板綍 + VipOrder order = vipOrderMapper.getByThreeOrderId(t.getThreeOrderId()); + if (order != null) { + throw new VipOrderException(1, "璇ヤ粯娆捐鍗曞彿宸插瓨鍦�"); + } + + // 鍒ゆ柇璁㈠崟绫诲瀷: 棣栧崟銆佺画璐� + OrderTypeEnum orderType = OrderTypeEnum.buyNewly; + long count = vipOrderMapper.countByTypeAndUid(t.getUid(), orderType); + if (count > 0) { + orderType = OrderTypeEnum.buyRenew; + } + + // 鎻掑叆璁㈠崟淇℃伅 + VipOrder newOrder = new VipOrder(); + newOrder.setComboId(t.getComboId()); + newOrder.setUid(t.getUid()); + newOrder.setThreeOrderId(t.getThreeOrderId()); + newOrder.setPayWay(t.getPayWay().name()); + newOrder.setType(orderType); + newOrder.setCreateTime(new Date()); + vipOrderMapper.insertSelective(newOrder); + + // 鏀粯鏂瑰紡 + return payOrder(newOrder); + } + + + @Override + @Transactional(rollbackFor = Exception.class) + public PayWayInfoDTO payOrder(VipOrder order) { + String goodsTitle = Constant.ORDER_PAY_TITLE; + String orderId = order.getId() + ""; + switch (order.getPayWay()) { + case "alipay": //鐢熸垚鏀粯瀹濇敮浠樿鍗� + if (order.getState() == VipOrder.STATE_PAY) { + return new PayWayInfoDTO(PayWayEnum.alipay.getWay(), PayUtil.getPaySuccessUrl(orderId)); } - //鐢熸垚鏀粯瀹濇敮浠樿鍗� - String form = VipUtil.getVipChargeAlipayForm(record.getId(), record.getOrderType(), orderNo, record.getMoney()); + String form = PayUtil.getVipChargeAlipayForm(orderId, goodsTitle, orderId, order.getPayMoney()); //鏆傚瓨2鍒嗛挓 String id = StringUtil.Md5(UUID.randomUUID().toString() + "#" + System.currentTimeMillis()); redisManager.cacheCommonString(id, form, 120); String payUrl = Constant.HOST + "/BuWan/alipay/printPayForm?formId=" + id; - orderLogger.info("璁㈠崟鍒涘缓鏀粯瀹濇敮浠橀摼鎺ユ垚鍔燂細id-{} 閾炬帴-{}", record.getId(), payUrl); - return new PayWayInfoDTO(OrderRecord - .PAY_WAY_ALIPAY, payUrl); - } - case OrderRecord.PAY_WAY_WX_GOLDCORN: + return new PayWayInfoDTO(PayWayEnum.alipay.getWay(), payUrl); + case "weChat": try { - goldCornManager.consumeGoldCorn(record, record.getGoldCorn()); - } catch (){ + if (order.getState() == VipOrder.STATE_PAY) { + return new PayWayInfoDTO(PayWayEnum.weChat.getWay(), PayUtil.getPaySuccessUrl(orderId)); + } + + String formWX = PayUtil.createWXOrder(orderId, null, orderId, order.getPayMoney(), goodsTitle); + //鏆傚瓨2鍒嗛挓 + String idWX = StringUtil.Md5(UUID.randomUUID().toString() + "#" + System.currentTimeMillis()); + redisManager.cacheCommonString(formWX, formWX, 120); + String payUrlWX = Constant.HOST + "/BuWan/alipay/printPayForm?formId=" + idWX; + return new PayWayInfoDTO(PayWayEnum.weChat.getWay(), payUrlWX); + } catch (Exception e) { + } } + return null; + } - @Transactional(rollbackFor = Exception.class) - @Override - public OrderRecord checkOrderPayState(String id) { - OrderRecord record = vipOrderRecordDao.find(OrderRecord.class, id); - if (record.getState() == OrderRecord.STATE_PAY) - return record; - - switch (record.getPayWay()) { - case OrderRecord.PAY_WAY_ALIPAY_GOLDCORN: - case OrderRecord.PAY_WAY_ALIPAY: { - //鏀粯瀹� - AlipayTradeQueryResponse res = null; - try { - res = AlipayH5PayUtil.queryOrder(VipUtil.getAlipayApp(), VIPOrderUtil.getOutOrderNo(record.getOrderType(), id), null); - //鏀粯鎴愬姛 - if (res.isSuccess() && "TRADE_SUCCESS".equalsIgnoreCase(res.getTradeStatus())) { - try { - return paySuccess(id, OrderRecord.PAY_WAY_ALIPAY, new BigDecimal(res.getTotalAmount()), new Date()); - } catch (Exception e) { - e.printStackTrace(); - } - } - } catch (AlipayApiException e) { - e.printStackTrace(); - } - } - - break; - case OrderRecord.PAY_WAY_WX_GOLDCORN: - case OrderRecord.PAY_WAY_WX: { - //寰俊 - try { - WXPayOrderInfoV3 info = WXPayV3Util.getPayOrderInfo(VIPOrderUtil.getOutOrderNo(record.getOrderType(), id), VipUtil.getWXAPP()); - if (info != null && info.getTrade_state().equalsIgnoreCase("SUCCESS")) { - paySuccess(id, record.getPayWay(), new BigDecimal(info.getAmount().getPayer_total()).divide(new BigDecimal(100), 2, RoundingMode.FLOOR), new Date()); - return record; - } - } catch (Exception e) { - e.printStackTrace(); - } - } - break; - } - return record; - + @Override + @Transactional(rollbackFor = Exception.class) + public VipOrder checkOrderPayState(Long id) { + VipOrder order = vipOrderMapper.selectByPrimaryKey(id); + if (order == null || order.getState() == VipOrder.STATE_PAY) { + return order; } + switch (order.getPayWay()) { + case "alipay": //鏀粯瀹� + AlipayTradeQueryResponse res = null; + try { + res = AlipayH5PayUtil.queryOrder(PayUtil.getAlipayApp(), id + "", null); + //鏀粯鎴愬姛 + if (res.isSuccess() && "TRADE_SUCCESS".equalsIgnoreCase(res.getTradeStatus())) { + try { + return paySuccess(order); + } catch (Exception e) { + e.printStackTrace(); + } + } + } catch (AlipayApiException e) { + e.printStackTrace(); + } + case "weChat": //寰俊 + try { + WXPayOrderInfoV3 info = WXPayV3Util.getPayOrderInfo(id + "", PayUtil.getWXAPP()); + if (info != null && info.getTrade_state().equalsIgnoreCase("SUCCESS")) { + paySuccess(order); + return order; + } + } catch (Exception e) { + e.printStackTrace(); + } + } + return null; + } + + + /** + * 鏀粯鎴愬姛鏇存柊澶勭悊 + * + * @param order + * @return + */ + @Transactional(rollbackFor = Exception.class) + public VipOrder paySuccess(VipOrder order) throws VipOrderException { + + VipCombo vipCombo = vipComboService.selectByPrimaryKey(order.getComboId()); + if (vipCombo == null) { + throw new VipOrderException(1, "璇ュ椁愪笉瀛樺湪"); + } + // 鏈夋晥澶╂暟 + Integer validDays = vipCombo.getValidDays(); + + // 鍒ゆ柇璁㈠崟绫诲瀷 + OrderTypeEnum orderType = OrderTypeEnum.buyNewly; + long count = vipOrderMapper.countByTypeAndUid(order.getUid(), orderType); + if (count > 0) { + orderType = OrderTypeEnum.buyRenew; + } + + // order.setThreeOrderId(); TODO + order.setState(VipOrder.STATE_PAY); + order.setPayTime(new Date()); + order.setUpdateTime(new Date()); + vipOrderMapper.updateByPrimaryKeySelective(order); + + // 鏇存柊绛夌骇 + vipCenterService.saveVipCenter(order.getUid(), vipCombo.getGradeId(), validDays * 24, order.getId()); + + return order; + } + } -- Gitblit v1.8.0