后端怎样防止重复提交订单?

参考文章

通常我们可以在前端通过防抖和节流来解决短时间内请求重复提交的问题,

如果因网络问题、Nginx重试机制、微服务Feign重试机制或者用户故意绕过前端防抖和节流设置,直接频繁发起请求,都会导致系统防重请求失败,甚至导致后台产生多条重复记录,此时我们需要考虑在后台增加防重设置。

考虑到微服务分布式的场景,可以通过使用Redisson分布式锁+自定义注解+AOP的 方式来实现后台防止重复请求的功能,

基本实现思路:

  1. 通过在需要防重的接口添加自定义防重注解,设置防重参数
  2. 通过AOP拦截请求参数,根据注解配置,生成分布式锁的Key,并设置有效时间。
  3. 每次请求访问时,都会尝试获取锁,如果获取到,则执行,如果获取不到,那么说明请求在设置的重复请求间隔内,返回请勿频繁请求提示信息。
相关推荐
qq_3331209717 分钟前
C++高并发内存池的整体设计和实现思路_C 语言
java·c语言·c++
mh_f20 分钟前
33.批量通过GET链接下载图片到指定文件夹下
java
金銀銅鐵22 分钟前
[Java] 如何理解 class 文件中方法的 access flags?
java·后端
智研数智工坊23 分钟前
SpringBoot4.0.6 + Security7.x + JWT 最新完整实战|无状态权限认证、统一异常处理、可直接落地
java·spring boot·spring security·jwt·权限认证
DIY源码阁25 分钟前
JavaSwing宿舍管理系统 - MySQL版
java·数据库·mysql·eclipse
Han_han91926 分钟前
递归相关题目:
java
kTR2hD1qb41 分钟前
Claude Code Skill的介绍与使用
java·前端·数据库·人工智能
汤米粥1 小时前
python学习——核心语法三
java·python·学习
basketball6161 小时前
Kadane算法 C++实现
java·c++·算法
better_liang1 小时前
每日Java面试场景题知识点之-如何设计分布式锁
java·redis·zookeeper·面试·分布式锁