幂等性(防重复提交)

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

1. 实现原理

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

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

2.使用示例

在Controller添加@Idempotent注解即可。
在这里插入图片描述

3. @Idempotent注解

在这里插入图片描述

  1. DefaultIdempotentKeyResolver默认的key解析器
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方法里面
在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值