From d3b1427b1e919cfb42004f9e5430f078b1399a8e Mon Sep 17 00:00:00 2001 From: rentaiming <806181062@qq.com> Date: 星期四, 13 六月 2024 18:08:55 +0800 Subject: [PATCH] 用户端商品 --- ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderServiceImpl.java | 50 +++++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 47 insertions(+), 3 deletions(-) diff --git a/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderServiceImpl.java b/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderServiceImpl.java index 3e46d1b..7ccf90f 100644 --- a/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderServiceImpl.java +++ b/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderServiceImpl.java @@ -5,6 +5,7 @@ import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.google.common.collect.Lists; +import com.ruoyi.common.core.constant.CacheConstants; import com.ruoyi.common.core.constant.SecurityConstants; import com.ruoyi.common.core.enums.OrderFromEnum; import com.ruoyi.common.core.enums.OrderStatusEnum; @@ -12,6 +13,9 @@ import com.ruoyi.common.core.exception.ServiceException; import com.ruoyi.common.core.utils.StringUtils; import com.ruoyi.common.core.utils.page.PageDTO; +import com.ruoyi.common.redis.service.RedisService; +import com.ruoyi.order.controller.management.dto.MgtMallOrderQuery; +import com.ruoyi.order.controller.management.vo.MgtMallOrderVO; import com.ruoyi.order.domain.Paylog; import com.ruoyi.order.mapper.OrderAuctionBondMapper; import com.ruoyi.order.mapper.OrderMapper; @@ -45,10 +49,15 @@ import java.time.LocalDateTime; import java.util.Collection; import java.util.List; +import java.util.concurrent.TimeUnit; import java.util.regex.Matcher; import java.util.regex.Pattern; import javax.annotation.Resource; + +import lombok.Synchronized; import org.apache.commons.beanutils.BeanUtils; +import org.redisson.api.RLock; +import org.redisson.api.RedissonClient; import org.springframework.stereotype.Service; /** @@ -82,6 +91,12 @@ @Resource private SysUserClient sysUserClient; + + @Resource + private RedissonClient redissonClient; + + @Resource + private RedisService redisService; @Override @@ -196,6 +211,7 @@ } @Override + @Synchronized public MemberTiOrderVO saveMemberOrder(MemberOrderDTO memberOrderDTO) { MemberTiOrderVO memberOrderVO=new MemberTiOrderVO(); @@ -242,8 +258,22 @@ pice=goodsSku.getPrice(); } if (memberOrderDTO.getOrderFrom()==2){ - order.setOrderFrom(OrderFromEnum.SNAP_ORDERS); GoodsSeckill data = goodsSkuClient.getGoodsSeckillOne(memberOrderDTO.getGoodsSkuId(), SecurityConstants.INNER).getData(); + /* String goodsLock = "goods_lock_" + CacheConstants.SECKILL_GOODS + data.getId(); + RLock redissonLock = redissonClient.getLock(goodsLock); + Integer surpNum = 0; + try { + redissonLock.lock(30, TimeUnit.SECONDS); + surpNum = redisService.getCacheObject(CacheConstants.SECKILL_GOODS + data.getId()); + if (surpNum == null || surpNum < memberOrderDTO.getGoodsQuantity()) { + throw new ServiceException("商品已被抢完"); + } + + }catch (Exception e){ + throw new ServiceException("reids 出错"); + }*/ + order.setOrderFrom(OrderFromEnum.SNAP_ORDERS); + GoodsSku goodsSku = goodsSkuClient.getGoodsSkuOne(data.getGoodsSkuId(), SecurityConstants.INNER).getData(); memberOrderVO.setGoodsSkuId(memberOrderDTO.getGoodsSkuId()); memberOrderVO.setPrice(goodsSku.getPrice()); @@ -264,7 +294,7 @@ order.setSkuName(goodsSku.getSkuName()); order.setPrice(data.getSeckillPrice()); order.setCoverPic(goodsSku.getCoverPic()); - + /*redisService.setCacheObject(CacheConstants.SECKILL_GOODS + data.getId(), surpNum - memberOrderDTO.getGoodsQuantity());*/ } if (memberOrderDTO.getOrderFrom()==3){ order.setOrderFrom(OrderFromEnum.GROUP_PURCHASE_ORDERS); @@ -329,6 +359,8 @@ memberOrderVO.setReceiverCity(order.getReceiverCity()); memberOrderVO.setReceiverDetailAddress(order.getReceiverDetailAddress()); memberOrderVO.setReceiverphone(order.getReceiverphone()); + Integer delayTime = 30; + redisService.setCacheObject(CacheConstants.ORDER_AUTOMATIC_CANCEL + "-" + order.getId(), order.getId() , delayTime.longValue(), TimeUnit.MINUTES); return memberOrderVO; } @@ -625,6 +657,18 @@ */ @Override public List<Order> getOrderByCouponIds(Collection<Long> couponIds) { - return this.lambdaQuery().in(Order::getCouponId, couponIds).list(); + return this.lambdaQuery().in(Order::getCouponId, couponIds) + .eq(Order::getOrderStatus, OrderStatusEnum.FINISHED).list(); + } + + /** + * 商城订单分页列表 + * + * @param query 商城订单查询对象 + * @return PageDTO<MgtMallOrderVO> + */ + @Override + public PageDTO<MgtMallOrderVO> getMallOrderPage(MgtMallOrderQuery query) { + return null; } } -- Gitblit v1.7.1