可以使用Redis的setnx命令来解决 @Override public void processOrder(Map<String, Object> plainTextMap) { String orderNo = (String) plainTextMap.get("out_trade_no"); try { TimeUnit.SECONDS.sleep(10); } catch (InterruptedException e) { e.printStackTrace(); } Boolean isFlag = redisTemplate.opsForValue().setIfAbsent(orderNo, "已支付"); log.info("还没修改~~~"); if (isFlag) { //修改订单支付成功 log.info("修改订单状态"); QueryWrapper<OrderInfo> queryWrapper = new QueryWrapper<>(); queryWrapper.eq("order_no", orderNo); OrderInfo orderInfo = new OrderInfo(); orderInfo.setOrderStatus(OrderStatus.SUCCESS.getType()); baseMapper.update(orderInfo, queryWrapper); //记录支付日志 paymentInfoService.createPaymentInfo(plainTextMap); String redisKey = (String) plainTextMap.get("attach"); redisTemplate.delete(redisKey); } }
微信支付成功后,异步通知同时多次通知如何拦截?[图片] 大佬们好 现在开发遇到一个情况,当微信支付完成后,会在同时[时间跨度1秒内]收到2个异步通知,这种情况下应该如何拦截掉多余通知呢? 我的业务逻辑是在收到异步通知后就执行一次,执行前会先去判断支付是否成功,并推送消息给客服,但是由于这个时间过短,所以每一次的判断都会是成功的,都会执行一次业务逻辑,一下会推送两条一样的消息 后端开发框架是larave 有没有什么好的办法屏蔽一次
2022-05-18