订单防重设计
订单重复提交概念
重复提交指,连点按钮进行重复提交操作,不包括刷新后的重新下单,重新下单已非同一订单的概念。
解决方案
前端防重机制
在前端按钮点击时禁用按钮或加锁,防止用户多次点击。
后端防重机制
利用Token机制
在订单生成前生成一个唯一的Token,保证每个订单提交时只允许携带一次Token。
基于数据库的唯一索引
通过对订单字段(如订单号、用户ID)创建唯一索引来防止重复数据的插入。
Token机制方案介绍
Token机制是一种常见的防止重复提交的手段,通常的工作流程如下:
- 用户发起订单请求时,后端生成一个唯一的Token(例如UUID),并将其存储在Redis中,同时将该Token返回给前端。
- 前端提交订单时,将Token携带至后端。
- 后端校验该Token是否有效,若有效则执行订单创建流程,同时删除Redis中的该Token,确保该Token只能使用一次。
- 如果该Token已被使用或过期,则返回错误信息,提示用户不要重复提交。
其他
上述订单防重设计,亦适应于某些其他的防重业务场景,可类似设计使用。