首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

实现重复提交重复点击

点击上方「蓝字」关注我们 0x01: 背景 同一条数据被用户点击了多次,导致数据冗余,需要防止弱网络等环境下的重复点击 0x02: 目标 通过在指定的接口处添加注解,实现根据指定的接口参数来重复点击...0x03: 说明 这里的重复点击是指在指定的时间段内多次点击按钮 0x04: 技术方案 springboot + redis锁 + 注解 使用 feign client 进行请求测试 0x05...:实战演练 1、根据接口收到 PathVariable 参数判断唯一 /** * 根据请求参数里的 PathVariable 里获取的变量进行接口级别重复点击 * *...} 2、根据接口收到的 RequestBody 中指定变量名的值判断唯一 /** * 根据请求参数里的 RequestBody 里获取指定名称的变量param5的值进行接口级别重复点击...java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; /** * TestControllerTest * @description 重复点击测试类

2.4K41
您找到你想要的搜索结果了吗?
是的
没有找到

Curator学习笔记(二)- 重复提交

根据了解,我们可以使用curator的读写锁来做一个分布式重复提交的策略。为什么采用curator来做这个事情的原因是curator提供的读写锁能够跨线程和jvm进行加锁。...如果不加锁,那么因为网络抖动或者线程切换,谁都不知道重复提交的token标志是否被其他请求修改。因此这块必然要采用加锁的方式。...对于放重复提交的一般规则来说,我无非就是将session提取出来,而session则是和用户绑定的,因此这块我们将userId作为放重复提交的判断标志,将token表示该用户下次提交的表单的有效token...} 测试代码 @RestController @RequestMapping(value = "/zklock") public class TestLock { /** * 重复提交...return ResponseResult.error(newToken); } } } 在浏览器中发送请求: 一些反思:通过逻辑分析,这里做的重复提交的工具适合做单个有序接口

36410

如何订单重复提交策略方法

但前端的限制仅能解决少部分问题,且不够彻底,后端自有的重复处理措施必不可少,义不容辞。 在接口实现中,我们常要求接口要满足幂等性,来保证多次重复请求时只有一次有效。...比如第三方支付前台回调和后台回调,第三方支付批量回调,慢性能业务逻辑(如用户提交退款申请,商家同意退货/退款等)或慢网络环境时,是重复处理的高发场景。...### 尝试 这里针对“用户提交退款申请”的例子,说明一下尝试过的重复处理方法的效果。...后端重复处理的方式,我们先后尝试了三种: #### (1)基于DB中退款订单状态的验证 这种方式简单直观,从DB查询出来的退款详情(包括状态)往往还可以用在后续逻辑中,没有花额外的工作专门应对重复请求的问题...但对于重复处理效果并不好:在前端添加重复提交前,每周平均在25笔;前端优化后,每周降到7笔。这个数量占总退款申请数的3%%,一个仍然无法接受的比例。

2K01

(抖) 前后端重复提交常用的那些方法

抖(Debounce)是一种防止重复提交的策略,它通过延迟一定时间来合并连续的操作,以确保只执行一次。...// 清除会话中的 token unset($_SESSION['submit_token']); } Token抖(利用随机生成的 token 来防止重复提交) $token = md5(...== $lastSubmitIP) { // 处理表单提交 $_SESSION['last_submit_ip'] = $userIP; } Cookie抖 (利用Cookie来防止在一段时间内的重复提交...); // 60秒内不允许重复提交 } 延时抖(在最后一次操作后的一段时间内,只执行一次提交操作) if (!...cache_get($cacheKey)) { // 处理表单提交 cache_set($cacheKey, 'submitted', 60); // 60秒内不允许重复提交 } 验证码抖(要求用户输入特定的验证码来提交表单

46220

Curator学习笔记(三) - zk重复提交2.0版

前几天,说要用curator的读写锁写一个分布式重复提交的工具包。然后今天作者就探索一下,在上次文章的末尾,作者说当时的这种方式解决不了大量表单使用相同的重复提交token上送。...其他都可能被视为重复的表单。但是作者后边想了想感觉这种情况还是比较少。很多时候表单都是单个提交的。所以我们先不考虑那种情况,因为如果考虑那种情况会比较复杂。...交由spring管理 DoubleSubmitAdvice 是对请求重复提交token的生成处理。...reSubmitLock.check(userId, token)) { logger.warn(MessageFormat.format("重复提交的表单...status) { System.out.println("不能重复提交表单"); } return status; } /**

18820

js节流函数和js防止重复提交的N种方法

应用情景 经典使用情景:js的一些事件,比如:onresize、scroll、mousemove、mousehover等; 还比如:手抖、手误、服务器没有响应之前的重复点击; 这些都是没有意义的,重复的无效的操作...节流函数 所谓的节流函数顾名思义,就是某个时刻限制函数的重复调用。 同样节流函数也是为了解决函数重复提交的问题,而防止重复提交的方法,不止节流函数一种实现。...方法汇总 本文整理了我在工作实践当中,觉的防止js重复提交,比较好用的方法,在这里和大家分享一下。...一、setTimeout + clearTimeout(节流函数)   本文提供两种实现方式:普通节流函数和闭包节流函数 二、设定flag/js加锁 三、通过disable 四、添加浮层比如loading...业务代码 lock = false; }); }); 总结 前两种方式实现起来比较方便,而后两种实现起来相对比较繁琐,如果是为了防止事件的多次触发,建议使用闭包,如果是表单提交

4.6K120

js节流函数和js防止重复提交的N种方法

应用情景 经典使用情景:js的一些事件,比如:onresize、scroll、mousemove、mousehover等; 还比如:手抖、手误、服务器没有响应之前的重复点击; 这些都是没有意义的,重复的无效的操作...节流函数 所谓的节流函数顾名思义,就是某个时刻限制函数的重复调用。 同样节流函数也是为了解决函数重复提交的问题,而防止重复提交的方法,不止节流函数一种实现。...方法汇总 本文整理了我在工作实践当中,觉的防止js重复提交,比较好用的方法,在这里和大家分享一下。...一、setTimeout + clearTimeout(节流函数)   本文提供两种实现方式:普通节流函数和闭包节流函数 二、设定flag/js加锁 三、通过disable 四、添加浮层比如loading...业务代码 lock = false; }); }); 总结 前两种方式实现起来比较方便,而后两种实现起来相对比较繁琐,如果是为了防止事件的多次触发,建议使用闭包,如果是表单提交

8.4K40

架构设计 | 接口幂等性原则,重复提交Token管理

GET:用于获取资源,不应有副作用,所以是幂等的; POST:用于创建资源,重复提交POST请求可能产生两个不同的资源,有副作用不满足幂等性; PUT:用于更新操作,重复提交PUT请求只会对其URL中指定的资源有副作用...支付前系统本地相关业务处理 ; 请求第三方支付服务执行扣款; 第三方支付返回处理结果; 本地服务基于支付结果响应客户端; 该业务流程中要处理相当复杂的问题,比如事务,分布式事务,接口延迟超时,客户端重复提交等等...BIGINT (20) NOT NULL AUTO_INCREMENT COMMENT '订单id', `token_id` VARCHAR (50) DEFAULT NULL COMMENT '重复提交...,订单是不能重复提交的,下面会演示如何控制,这里业务是执行后推到完成,也可能业务向前清理,把整个流程置为失败,这里涉及关键状态判断,要选取一个状态作为成功或失败的标识,判断后续操作流程。...三、接口重复提交 1、表单重复提交 在实际情况中,接口如果处理时间过长,用户可能会点击多次提交按钮,导致数据重复

77650

如何防止表单重复提交

问题 在看Java Web 深入分析时, 看到表单重复提交问题一节, 如下描述如何解决问题: 要防止表单重复提交, 就要标识用户的每一次访问请求, 使得每一次访问对服务端来说都是唯一的....如果一致, 则说明没有重复提交, 否则用户提交上来的token已经不是当前这个请求的合法token. 流程图如下: ?...但是让我迷惑的是: 访问服务器时获得唯一的token标识, 然后提交时带上这个标志, 服务器检测是否和自己Session中的内容一致. 为什么这样就可以防止重复提交?...我提交的第二次, 第三次还是带有相同的token啊, 服务器检测Session中的内容应该还是一致的. 为什么可以防止重复提交?...服务端的事情没有办法减少, 那么就从客户端入手, 当客户端重复提交时, 通过JavaScript脚本阻止用户提交. 当客户提交表格时, 可以通过JavaScript脚本里的变量来表示用户是否提交.

2.7K40
领券