API接口幂等设计(Token方式防止表单重复提交或网络延迟)

场景要求:页面的数据只能被点击提交一次

发生原因:由于重复点击或者网络重发,或者 nginx 重发等情况会导致数据被重复提交

解决办法:

集群环境:采用 token 加 redis(redis 单线程的,处理需要排队)
单 JVM 环境:采用 token 加 redis 或 token 加 jvm 内存

处理流程:

数据提交前要向服务的申请 token,token 放到 redis 或 jvm 内存,token 有效时间
提交后后台校验 token,同时删除 token,生成新的 token 返回

幂等性

确保数据的唯一性

客户端解决

一般方法,前端是在点击提交按钮后, 把表单按钮进行置灰

后端解决: 使用token方式

代码如下

Jsp 页面user.jsp

在这里插入图片描述

前端提交到后台的用户实体类

在这里插入图片描述

生成Token的工具类

在这里插入图片描述

利用Aop技术对于需要进行重复提交或网络延迟的方法进行切面封装处理

自定义注解

在这里插入图片描述

切面类

在这里插入图片描述

controller 类

页面跳转时生成token,并加入表单隐藏域, 提交表单,
在这里插入图片描述
通过以上技术 aop 拦截指定切面, 注解指定哪些需要进行唯一性保证

使用图形验证码防止机器模拟接口请求攻击,在调用核心业务接口时,比如支付、下单、等接口,最好使用手机短信验证验证或者是人脸识别,防止其他用户使用Token伪造请求。

  • 2
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值