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

参考文章

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

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

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

基本实现思路:

  1. 通过在需要防重的接口添加自定义防重注解,设置防重参数
  2. 通过AOP拦截请求参数,根据注解配置,生成分布式锁的Key,并设置有效时间。
  3. 每次请求访问时,都会尝试获取锁,如果获取到,则执行,如果获取不到,那么说明请求在设置的重复请求间隔内,返回请勿频繁请求提示信息。
相关推荐
rgeshfgreh10 小时前
Spring事务传播机制深度解析
java·前端·数据库
无名-CODING10 小时前
Java Spring 事务管理深度指南
java·数据库·spring
xiaolyuh12310 小时前
Spring MVC Bean 参数校验 @Validated
java·spring·mvc
蕨蕨学AI10 小时前
【Wolfram语言】45.2 真实数据集
java·数据库
予枫的编程笔记10 小时前
【Java集合】深入浅出 Java HashMap:从链表到红黑树的“进化”之路
java·开发语言·数据结构·人工智能·链表·哈希算法
ohoy10 小时前
RedisTemplate 使用之Set
java·开发语言·redis
mjhcsp10 小时前
C++ 后缀数组(SA):原理、实现与应用全解析
java·开发语言·c++·后缀数组sa
8***f39510 小时前
Spring容器初始化扩展点:ApplicationContextInitializer
java·后端·spring
r_oo_ki_e_10 小时前
java22--常用类
java·开发语言
linweidong11 小时前
C++ 中避免悬挂引用的企业策略有哪些?
java·jvm·c++