前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >防止表单重复提交的思路和方法

防止表单重复提交的思路和方法

作者头像
java达人
发布于 2018-01-31 10:13:01
发布于 2018-01-31 10:13:01
2K0
举报
文章被收录于专栏:java达人java达人

作为一个软件开发者,绝不能奢望你的用户会规规矩矩地使用你的软件,他们一般都是缺乏耐心,“胡作非为”的。比如当他点击提交表单时,服务器处理比较慢, 页面上没有任何反应,他会迫不及待地再点击几次,这样就会产生重复数据或者报错,或者他会刷新一下再次提交。所以,你必须保证你的软件足够地健壮,尽可能地考虑各种用例,增加限制,抵御使用者的摧残。

对于如何处理重复提交,一般教科书上都有点明,不外乎是在js代码中增加限制或者通过session来处理。关于js代码限制,就是当用户第一次提交后,将提交按钮设置为“disable”状态,或者直接不提交重复请求,这只能处理用户重复连续点击的情况,如果用户刷新页面后再次提交,这种方法就无济于事了,因此我们更多的是通过session处理,就是在访问表单提交页时,服务器端生成一个随机序列,存储在session中,并传递到客户端,用户提交时,连同这个序列一起传递到服务器,后端程序会判断这两个序列是否一致,如果一致,表明是第一次提交,否则就是重复提交。

但是在多服务器多用户的场景下,以上方法也都会失效,在多服务器场景下,session存在于每台服务器中,请求是通过负载均衡机制分配到各台服务器上的,要通过session防止重复提交,必须有一套定向分派请求或者session共享的机制,就算你实现了,如何处理多用户请求的情况呢,比如在一个母帐号下,有多个子帐号,每个子帐号都有权限操作某一块业务,当多人同时登录操作这一块业务时,一定会出现类似于多线程并发访问共享资源的问题,那该如何解决呢?

世界上很多道理都是相通的,古人常将齐家治国联系在一起,你在齐家过程中得出的一些经验一定程度上可以用于治国领域,同样,处理多线程问题的一些思路方法也可以给多服务器多用户访问设计提供借鉴,处理并发问题最常用的一个方法就是加锁,当一个请求发出,服务器正在处理时,待处理的资源就处于锁定状态,后续的相关请求被抛弃或者进入阻塞队列等待,待处理完毕资源解锁。基本思路是这样,那我们通过什么具体方法,中间件实现这一设计呢,我们可以使用redis缓存,相比于session,它并不仅仅针对于特定用户会话,也就是说它可以处理多个用户同时提交同一类请求的情况。

每个请求都将带有表示某块资源的唯一标识KEY_NAME,当第一次请求时,redis 会执行INCR KEY_NAME命令,这是个原子递增操作,值变为1,于是后续同类请求会将它依次递增为2,3,4........,当值大于1时,表示资源已在处理中,后续请求被抛弃或处于等待状态,待处理完毕,将值重新设为0,表示资源已解锁可用。这是借助redis缓存实现的类加锁机制,解决多服务器多用户场景下请求重复提交的情况。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2016-04-04,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 java达人 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
防止用户将表单重复提交的方法 原
表单重复提交是在多用户Web应用中最常见、带来很多麻烦的一个问题。有很多的应用场景都会遇到重复提交问题,比如:
wuweixiang
2018/08/14
2.1K0
如何防止表单重复提交
在看Java Web 深入分析时, 看到表单重复提交问题一节, 如下描述如何解决问题:
望天
2018/08/02
3.3K0
如何防止表单重复提交
【干货】如何防止接口重复提交?(中)
在上一篇文章中,我们详细的介绍了对于下单流量不算高的系统,可以通过请求唯一ID+数据表增加唯一索引约束这种方案来实现防止接口重复提交!
Java极客技术
2022/12/04
1.7K0
【干货】如何防止接口重复提交?(中)
JavaWeb防止表单重复提交的几种方式
(4)、ajax提交加锁 采用ajax方式提交表单时,设置一个布尔变量(true/false),当然其他类型变量也可以。初始时为true可以提交,在前端向服务器发出请求后,服务端响应结果没有回来之前将该值置为false,正常响应时再置为true。
全栈程序员站长
2022/08/04
2.4K0
【干货】如何防止接口重复提交?(下)
在上一篇文章中,我们详细的介绍了随着下单流量逐渐上升,为了降低数据库的访问压力,通过请求唯一ID+redis分布式锁来防止接口重复提交,流程图如下!
Java极客技术
2022/12/04
1.1K0
【干货】如何防止接口重复提交?(下)
防止Web表单重复提交的方法总结
在Web开发中,对于处理表单重复提交是经常要面对的事情。那么,存在哪些场景会导致表单重复提交呢?表单重复提交会带来什么问题?有哪些方法可以避免表单重复提交?
编程随笔
2019/09/11
4.9K0
防止Web表单重复提交的方法总结
实战之防止表单重复提交
对于防止重复提交,最简单也最不安全的做法相信大家也都经历过,前端在一个请求发送后立即禁用掉按钮,这里咱们来讨论一下后端对防止重复提交的处理方式。 主要针对非分布式环境下防止重复提交与分布式环境下的防止重复提交。一般分布式环境下也可以通过网关路由的方式将同一个用户的请求路由到一个实例上处理。
山行AI
2019/06/28
3K0
面试必会的重复提交 8 种解决方案!
重复提交看似是一个小儿科的问题,但却存在好几种变种用法。在面试中回答的好,说不定会有意想不到的收获!现把这 8 种解决方案分享给大家!
业余草
2019/09/18
6810
面试必会的重复提交 8 种解决方案!
利用Redis实现防止接口重复提交功能
在划水摸鱼之际,突然听到有的用户反映增加了多条一样的数据,这用户立马就不干了,让我们要马上修复,不然就要投诉我们。
秃头哥编程
2022/04/27
1.3K0
11. 分布式系统接口,如何避免表单的重复提交?
关于怎么实现承载更多用户量的系统,一直是我重点关注的一个技术方向。改造架构提高承载力,通常来讲分为两个大方向,互相配合实现。
用户11332765
2024/10/28
1660
Curator学习笔记(二)- 防重复提交
上一篇文章中我们大概了解了Curator做读写锁的原理和过程。根据了解,我们可以使用curator的读写锁来做一个分布式防重复提交的策略。为什么采用curator来做这个事情的原因是curator提供的读写锁能够跨线程和jvm进行加锁。如果不加锁,那么因为网络抖动或者线程切换,谁都不知道防重复提交的token标志是否被其他请求修改。因此这块必然要采用加锁的方式。通过锁的创建和删除来保持多个重复请求的有序性,在保证有序性之后,我们就可以按照逻辑对token进行修改,这样其他线程就能够判断自身是否为重复请求。除此之外,在加锁的时候我们采用临时znode,在会话结束之后就可以自动销毁。因此可以避免zk服务端被累计打满的情况。当然这块的会话时间是可以根据业务需求设置的。对于放重复提交的一般规则来说,我无非就是将session提取出来,而session则是和用户绑定的,因此这块我们将userId作为放重复提交的判断标志,将token表示该用户下次提交的表单的有效token,因此同一时刻,只允许同一用户提交一个表单,否则就会因为抢占token,而导致后一表单提交被认定为重复的提交(这块需要优化,下一个版本再优化!)。
写一点笔记
2022/08/11
4260
Curator学习笔记(二)- 防重复提交
重复提交,你是如何处理的?
今天早上,新来的同事小王突然问我:“周哥,什么是幂等性啊?”。然后我就跟他解释了一番,幂等性就是说无论你执行几次请求,其结果是一样的。说到了幂等就不得不说重复提交了,你连续点击提交按钮,理论上来说这是同一条数据,数据库应该只能存入一条,而实际上存放了多条,这就违反了幂等性。因此我们就需要做一些处理,来保证连续点击提交按钮后,数据库只能存入一条数据。
Java旅途
2020/07/16
1.2K0
网络抖动对重复提交的影响与解决方案
还记得上次的文章提到技术经理离职了,目前为止,我在代理技术经理的工作,包括评审,周会等,最头疼的是要面对老板开周会,自己一个人面对需求的评审,技术设计,发版,解决方案,线上问题排查,疑难问题解决方案设计,这让我应接不暇。
疯狂的KK
2023/06/30
7400
WEB安全新玩法 [8] 阻止订单重复提交
交易订单的重复提交虽然通常不会直接影响现金流和商品流,但依然会给网站运营方带来损害,如消耗系统资源、影响正常用户订单生成、制造恶意用户发起纠纷的机会等。倘若订单对象是虚拟商品,也有可能造成实际损失。订单重复提交的检查工作本应该由网站自身实现,而 iFlow 业务安全加固平台则可以为未实现这项功能的网站提供防护。
天存信息
2021/07/28
1.6K0
WEB安全新玩法 [8] 阻止订单重复提交
重复提交,你是如何处理的?
今天早上,新来的同事小王突然问我:“周哥,什么是幂等性啊?”。然后我就跟他解释了一番,幂等性就是说无论你执行几次请求,其结果是一样的。说到了幂等就不得不说重复提交了,你连续点击提交按钮,理论上来说这是同一条数据,数据库应该只能存入一条,而实际上存放了多条,这就违反了幂等性。因此我们就需要做一些处理,来保证连续点击提交按钮后,数据库只能存入一条数据。
Java旅途
2020/06/25
1.1K0
JavaWeb学习(1) 使用Session和Token防止表单重复提交
前言 以前在很多p2p网站中,都有新手领取红包的活动。这样的红包链接或多或少都有很多的漏洞,就是表单可以重复提交。这样的话,对那些p2p网站或者其他类似的网站造成很大的损失。Fiddler大家都不陌生吧,就是一个抓包软件。我们先拦截url请求,Shift+R,填入压力测试的次数,然后释放,就会造成很多次的url访问请求,这样的结果很容易造成表单重复提交。那么我们的今天主题就是如何使用Session和Token防止表单重复提交 ---- 表单重复提交例子 在我们写网站的时候,肯定写过留言板的功能,但是肯定对重
用户2032165
2018/06/05
1.5K0
防止重复提交3种方法
2 还是javascript,将提交按钮或者image置为disable 3 利用struts的同步令牌机制 利用同步令牌(Token)机制来解决Web应用中重复提交的问题,Struts也给出了一个参考实现。 基本原理:
PHP开发工程师
2021/05/05
1.4K0
JSP 防止网页刷新重复提交数据
if session("ok")=true then    response.write "错误,正在提交"    response.end end if
阳光岛主
2019/02/19
12.2K0
Redis缓存技术及应用场景案例
    Remote Dictionary Server(Redis) 是一个开源的由Salvatore Sanfilippo使用ANSI C语言开发的key-value数据存储服务器。其值(value)可以是 字符串(String), 哈希(Map), 列表(list), 集合(sets) 和 有序集合(sorted sets)等类型,所以它通常也被称为数据结构服务器。
动力节点Java培训
2019/06/12
1.5K0
解决分布式表单重复提交问题
3.1 前端解决办法:通过前端的方法将提交按钮变灰。对于前端的办法这里就不做演示了,因为前端的控制虽然能够防止数据的重复提交但是治标不治本。这里主要介绍第二种方法。
林老师带你学编程
2019/05/25
7700
相关推荐
防止用户将表单重复提交的方法 原
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档