防重方案-订单防重方案笔记

订单防重设计

订单重复提交概念

重复提交指,连点按钮进行重复提交操作,不包括刷新后的重新下单,重新下单已非同一订单的概念。

解决方案

前端防重机制

在前端按钮点击时禁用按钮或加锁,防止用户多次点击。

后端防重机制

利用Token机制

在订单生成前生成一个唯一的Token,保证每个订单提交时只允许携带一次Token。

基于数据库的唯一索引

通过对订单字段(如订单号、用户ID)创建唯一索引来防止重复数据的插入。

Token机制方案介绍

Token机制是一种常见的防止重复提交的手段,通常的工作流程如下:

  1. 用户发起订单请求时,后端生成一个唯一的Token(例如UUID),并将其存储在Redis中,同时将该Token返回给前端。
  2. 前端提交订单时,将Token携带至后端。
  3. 后端校验该Token是否有效,若有效则执行订单创建流程,同时删除Redis中的该Token,确保该Token只能使用一次。
  4. 如果该Token已被使用或过期,则返回错误信息,提示用户不要重复提交。

其他

上述订单防重设计,亦适应于某些其他的防重业务场景,可类似设计使用。

相关推荐
kevinzeng4 小时前
JdbcTemplate常用方法
后端
yunxi_054 小时前
分布式文件服务实战稿:从本地存储到对象存储的架构升级
后端·面试
weixin_307779135 小时前
基于AWS的应用程序可靠性提升架构优化方案——RDS多可用区与EC2弹性架构实践
数据库·数据仓库·架构·云计算·aws
Chan165 小时前
【 Java八股文面试 | Redis篇 缓存问题、持久化、分布式锁 】
java·数据库·redis·后端·spring·缓存·面试
q***47185 小时前
Spring Boot 整合 Druid 并开启监控
java·spring boot·后端
bagadesu5 小时前
MySQL----case的用法
java·后端
hour_go6 小时前
DeepHunt微服务故障定位系统核心技术解析2
微服务·云原生·架构·deephunt
百***58146 小时前
Spring Boot 2.7.x 至 2.7.18 及更旧的版本,漏洞说明
java·spring boot·后端
q***38517 小时前
Spring boot启动原理及相关组件
数据库·spring boot·后端
自己的九又四分之三站台7 小时前
PlantUML--结合大模型快速出土
架构