防重复提交注解

该文章介绍了一种使用SpringAOP和Redis实现的方法,通过注解`@NoRepeatSubmit`来防止控制器层的重复提交。系统在接收到请求时,检查Redis缓存中的session标识和URL路径,如果存在则认为是重复请求并返回错误信息,否则正常处理请求并设置缓存。
摘要由CSDN通过智能技术生成

防重复提交 标记注解

@Target(ElementType.METHOD) // 作用到方法上
@Retention(RetentionPolicy.RUNTIME) // 运行时有效
public @interface NoRepeatSubmit {
}

防止重复提交切面类

@Aspect
@Component
public class NoRepeatSubmitAop {

    @Autowired
    private RedisUtil redisUtil;
	 /**
     * 调用controller包下的任意类的任意方法时均会调用此方法
     */
    @Around("execution(public * com.ciip.cloud.core.usercenter.controller..*.*(..)) && @annotation(nrs)")
    public Object arround(ProceedingJoinPoint pjp, NoRepeatSubmit nrs) {
        try {
            ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
            String sessionId = RequestContextHolder.getRequestAttributes().getSessionId();
            HttpServletRequest request = attributes.getRequest();
            String key ="-" + request.getServletPath();
            // 如果缓存中有这个url视为重复提交
            if (redisUtil.get(sessionId,key) == null) {
                redisUtil.setWithExpireTime(sessionId,key,"0",2);
                Console.log("请求=========" + sessionId + key);
                //继续下一个通知或目标方法调用
                Object o = pjp.proceed();
                return o;
            } else {
                Console.log("重复请求=========" + sessionId + key);
                return ResultUtil.error(UserCenterStatusCode.REPEAT_SUBMIT.getCode(),UserCenterStatusCode.REPEAT_SUBMIT.getMsg());
            }
        } catch (Throwable e) {...}
    }
}

实例:在Controller层上加上注解@NoRepeatSubmit,即可

    @NoRepeatSubmit
    @PostMapping("/xx")
    public ResponseMessage againJoinCooperationRecord(){...}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值