06、SpringBoot+微信支付 -->商户定时查订单状态、用户取消订单(关闭订单API)、查询订单API--到微信支付平台查询订单

本文描述了针对Native应用的订单功能完善需求,包括商户定时查询订单状态、用户取消订单(通过关闭订单API)以及查询未收到支付结果通知的订单。后端主要通过微信支付接口获取订单状态并提供相应的API支持,前端与后端代码实现,配合Swagger进行测试验证。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Native 下单、取消订单

订单功能完善

商户定时查订单状态、用户取消订单(关闭订单API)、查询订单API–到微信支付平台查询订单

需求1:商户定时查单

用户点击确认支付,弹出这个支付二维码,在弹出这个二维码的期间内,会调用定时查该订单的方法,如果该订单支付了,就跳转到订单列表。

如果关闭这个二维码,就不会去触发这个定时查询该订单支付状态的方法了。

在这里插入图片描述

前端代码:

代码执行思路
在这里插入图片描述

在这里插入图片描述

后端代码:

就是简单的通过订单的编号获取订单的支付状态,进行判断和返回数据给前端就可以了。

在这里插入图片描述

测试:
swagger 测试:

在这里插入图片描述

在这里插入图片描述
经过测试,可以得到在扫码支付,得到响应的3秒后,能成功的调到这个订单列表页面

在这里插入图片描述

需求2:用户取消订单(关闭订单API)

关闭订单

需求:

根据订单号取消订单-------->点击取消支付,弹出提示框,修改订单状态,关闭订单api。

这个关闭订单API:调用微信支付的关单接口,调用这个关闭订单的接口,该订单就不能再支付了。

在这里插入图片描述

代码:
前端:

在这里插入图片描述

后端:

WxPayController

在这里插入图片描述
WxPayServiceImpl

在这里插入图片描述

调用微信支付的关单接口

在这里插入图片描述
在这里插入图片描述

根据订单号更新订单状态
在这里插入图片描述

测试:

在这里插入图片描述

我把关闭下单api的方法注释掉了,只修改订单状态,发现重新下单的时候,支付二维码也是会变的。

得出的结论是,只有订单的支付状态是【未支付】的情况下,才不会调用微信支付的下单接口,直接返回已有的二维码url,其他支付状态,都是获取新的支付二维码url。

在这里插入图片描述

点击取消支付,弹出提示框,修改订单状态,关闭订单api。

在这里插入图片描述

需求3:查询订单API–到微信支付平台查询订单

需求:

**查询一直没有收到支付结果通知的订单,是根据订单编号调用微信平台的【商户订单号查询订单】接口来查 **

原本支付通知时商户通过二维码扫码支付后,微信支付端那边自动发来的。

如果商户端一直没有收到微信支付端发来的支付通知,比如5分钟或者10分钟,就主调去调用微信支付端的查单的接口。

就是通过商品的订单号,到【微信支付平台】那边查询这个订单的支付情况

注意不是去数据库查,是去微信支付平台查,相当于查支付通知。

商户订单号查询订单

 * 注意:这个【商户订单号查询订单】接口查出来的数据是明文不是密文,不要想成是密文
 * 而且查出来的数据 跟支付通知里面的通知参数的密文ciphertext解密出来的数据是一样的

在这里插入图片描述

代码:
后端:

WxPayController

在controller写接口只是为了测试,后续定时调用的时候是直接调用业务方法

在这里插入图片描述

WxPayServiceImpl
在这里插入图片描述
在这里插入图片描述

swagger测试:

成功通过商品的订单号,到微信支付平台那边查询这个订单的支付情况

在这里插入图片描述

### SpringBoot微信支付订单过期处理流程 在 SpringBoot 实现微信支付的过程中,订单过期是一个常见的业务场景。以下是关于如何处理订单过期的具体方法: #### 1. 设置订单有效时间 当用户提交订单时,在数据库中记录该订单的创建时间和有效期。通常可以通过 `order_time` 和 `expire_time` 字段来表示订单的时间范围。 ```java @Entity public class Order { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String orderId; // 商户订单号 private Date orderTime; // 创建时间 private Date expireTime; // 过期时间 private BigDecimal totalAmount; // 总金额 private Integer status; // 订单状态 (0:未支付, 1:已支付, 2:已取消) // Getter and Setter methods... } ``` 通过设置合理的超时时长(如30分钟),计算并存储订单的过期时间[^4]。 --- #### 2. 定时任务检测订单状态 利用 Spring定时任务功能定期检数据库中的订单状态。如果当前时间为某个订单的过期时间之后,则更新其状态为“已取消”。 ```java @Component public class OrderTimeoutTask { @Autowired private OrderRepository orderRepository; /** * 每隔一分钟执行一次任务 */ @Scheduled(cron = "0 */1 * * * ?") public void checkOrderStatus() { List<Order> ordersToCancel = orderRepository.findOrdersByStatusAndExpireTimeBefore( Constants.ORDER_UNPAID_STATUS, new Date() ); for (Order order : ordersToCancel) { order.setStatus(Constants.ORDER_CANCELED_STATUS); order.setUpdateTime(new Date()); orderRepository.save(order); log.info("Order {} has been canceled due to timeout.", order.getOrderId()); } } } ``` 上述代码片段展示了如何通过定时器机制自动关闭超时未付款的订单[^1]。 --- #### 3. 用户主动查询订单状态 除了后台轮询外,还可以允许前端应用请求服务器以实时获取订单的状态信息。例如,当用户打开订单详情页时触发 API 调用。 ```java @RestController @RequestMapping("/orders") public class OrderController { @Autowired private OrderService orderService; @GetMapping("/{orderId}") public ResponseEntity<?> getOrderDetails(@PathVariable String orderId) { Optional<Order> optionalOrder = orderService.findById(orderId); if (!optionalOrder.isPresent()) { return ResponseEntity.status(HttpStatus.NOT_FOUND).body("No such order."); } Order order = optionalOrder.get(); if (new Date().after(order.getExpireTime())) { order.setStatus(Constants.ORDER_CANCELED_STATUS); // 更新状态为已取消 orderService.update(order); return ResponseEntity.ok(Map.of("status", "canceled")); } return ResponseEntity.ok(order); } } ``` 此部分逻辑确保即使定时任务未能及时捕获某些异常情况下的订单到期事件,也能由客户端再次验证并同步数据一致性[^3]。 --- #### 4. 支付完成后通知服务端 无论何时发生实际支付行为,都需要依赖于微信官方推送过来的通知消息来进行最终确认。因此需特别注意监听来自微信服务器发出的结果反馈包,并据此调整本地数据库里对应条目的属性值至已完成阶段;与此同时也要考虑网络延迟等因素可能造成重复接收相同的消息情形下采取幂等性设计原则加以防范错误累积现象的发生[^2]。 --- ### 小结 综上所述,在 Spring Boot 应用程序中实现针对微信支付过程中可能出现的各种状况——尤其是涉及订单时效管理方面的工作流控制方案主要包括以下几个关键环节:合理设定初始参数约束条件、借助框架内置工具完成周期性核操作以及配合外部交互渠道共同维护整体系统的稳定性和可靠性水平。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_L_J_H_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值