幂等性(防重复提交)

文章目录

  • [1. 实现原理](#1. 实现原理)
  • 2.使用示例
  • [3. @Idempotent注解](#3. @Idempotent注解)
  • [4. debug过程](#4. debug过程)

主要用途:防止用户快速双击某个按钮,而前端没有禁用,导致发送两次重复请求。

1. 实现原理

幂等性要求参数相同的方法在一定时间内,只能执行一次。本质上是基于redis的分布式锁。大体有以下步骤:

  • 方法执行前,利用MD5算法(不仅限于此),将方法名 + 方法参数计算获得一个key
  • 查询redis的key是否存在
    • 存在,则不执行方法
    • 不存在,将key存到redis,并设置过期时间,接着执行方法
  • 需要注意方法执行的时间不能超过过期时间

2.使用示例

在Controller添加@Idempotent注解即可。

3. @Idempotent注解

  1. DefaultIdempotentKeyResolver默认的key解析器
java 复制代码
public class DefaultIdempotentKeyResolver implements IdempotentKeyResolver {

    @Override
    public String resolver(JoinPoint joinPoint, Idempotent idempotent) {
    // 获得方法名
        String methodName = joinPoint.getSignature().toString();
        // 将参数拼接成字符串
        String argsStr = StrUtil.join(",", joinPoint.getArgs());
        // md5计算一个key
        return SecureUtil.md5(methodName + argsStr);
    }

}
  1. 对应AOP切面类IdempotentAspect
    核心代码如下:
  2. 生成的key加了前缀"idempotent",参看IdempotentRedisDAO。

4. debug过程

进入resolver方法里面

相关推荐
程序员皮皮林1 天前
Java jar 如何防止被反编译?代码写的太烂,害怕被人发现
java·开发语言·jar
橙序员小站1 天前
搞定系统面试题:如何实现分布式Session管理
java·后端·面试
叫我阿柒啊1 天前
从Java全栈到Vue3实战:一次真实面试中的技术探索
java·数据库·spring boot·微服务·typescript·vue3·restful
武子康1 天前
Java-118 深入浅出 MySQL ShardingSphere 分片剖析:SQL 支持范围、限制与优化实践
java·大数据·数据库·分布式·sql·mysql·性能优化
努力努力再努力wz1 天前
【c++进阶系列】:万字详解AVL树(附源码实现)
java·运维·开发语言·c++·redis
爱学习de测试小白1 天前
13-Java-面向对象-封装和this关键字
java
-哈喽沃德-1 天前
Date、BigDecimal类型值转换
java
凉、介1 天前
U-Boot 多 CPU 执行状态引导
java·服务器·前端
一个尚在学习的计算机小白1 天前
spring
android·java·spring
csdn_clwjc1 天前
synchronized 锁升级
java·juc