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

关于表单重复提交问题

问题引入:当我们在做一个页面数据提交的时候,当我们连续点击提交按钮,因为快速连续点击,因为速度过快,页面还来不及反应,导致页面从复提交。。...问题解决:   对于问题又会设计到以下几种情况:     1、我们利用Ajxax进行页面提交,对于这中情况,非常好解决,我们只需在页面设置一个变量“hasSubmit=false”,在ajax提交前对其...“hasSubmit”验证,如果hasSubmit==false才提交表单,在提交表单的同时修改hasSubmit=true,ajax提交完成时,在次修改hasSubmit=false即可完成。.../Plugin/swfobject.js" type="text/javascript"> var hasSubmit = false; //记录用户是否已经提交了表单 $(function () { //表单验证JS

1.8K20

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

比如当他点击提交表单时,服务器处理比较慢, 页面上没有任何反应,他会迫不及待地再点击几次,这样就会产生重复数据或者报错,或者他会刷新一下再次提交。...关于js代码限制,就是当用户第一次提交后,将提交按钮设置为“disable”状态,或者直接不提交重复请求,这只能处理用户重复连续点击的情况,如果用户刷新页面后再次提交,这种方法就无济于事了,因此我们更多的是通过...session共享的机制,就算你实现了,如何处理多用户请求的情况呢,比如在一个母帐号下,有多个子帐号,每个子帐号都有权限操作某一块业务,当多人同时登录操作这一块业务时,一定会出现类似于多线程并发访问共享资源的问题...世界上很多道理都是相通的,古人常将齐家治国联系在一起,你在齐家过程中得出的一些经验一定程度上可以用于治国领域,同样,处理多线程问题的一些思路方法也可以给多服务器多用户访问设计提供借鉴,处理并发问题最常用的一个方法就是加锁...这是借助redis缓存实现的类加锁机制,解决多服务器多用户场景下请求重复提交的情况。

1.9K80
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    解决分布式表单重复提交问题

    一、为什么会出现重复提交? 主要是由于网络的延迟问题以及页面刷新的操作。 二、表单的重复提交会导致的问题? 主要能够造成很多脏数据。...request.getSession().removeAttribute("sessionToken"); return true; } } 这篇博客利用session结合token来解决表单重复提交的问题...但是对于分布式项目而言,还是没有解决分布式下面的表单重复提交问题。所以我对基于session的表单验证,做了一些优化,采用redis+totekn的方式来解决分布式下面表单重复提交的问题。...前端app处理和上面的一样,点击之后按钮马上变为灰色。后端进行了一些修改。 修改内容: 用户在进入表单页面的时候会生成一个token,返回给前端。...用户每次提交表单的时候都会将redis中用户所对应的key删除掉。通过这种方式就可以完美的解决分布式下面表单重复提交的问题了。

    73710

    防止Web表单重复提交的方法总结

    在Web开发中,对于处理表单重复提交是经常要面对的事情。那么,存在哪些场景会导致表单重复提交呢?表单重复提交会带来什么问题?有哪些方法可以避免表单重复提交? ?...但是,是否需要这样做,需要考虑用户的操作体验是不是可以接受。 在前端拦截虽然可以解决场景一的表单重复提交问题,但是针对场景二(刷新)和场景三(后退重新提交)的表单重复提交是无能为力的。 ?...显然,通过在服务端保存token的方式拦截场景二和场景三的表单重复提交是非常有效的。而且,这种方式同样可以拦截场景一的表单重复提交。 ?...也就是说,对于拦截表单重复提交的终极解决方案是在服务器端进行拦截!不过,考虑到用户操作体验的问题,可能需要同时在前端进行拦截,这可以根据具体的产品设计而定。 ?...另外,有意思的是:在最新的Firefox浏览版本(Firefox Quantum 59.0.1 64位)中,浏览器自己就能处理场景一的表单重复提交(但是不能处理场景二和场景三的表单重复提交)。

    4.8K20

    JavaWeb防止表单重复提交的几种方式

    一、表单重复提交的常见应用场景 网络延迟的情况下用户多次点击submit按钮导致表单重复提交 用户提交表单后,点击【刷新】按钮导致表单重复提交(点击浏览器的刷新按钮,就是把浏览器上次做的事情再做一次,因为这样也会导致表单重复提交...) 用户提交表单后,点击浏览器的【后退】按钮回退到表单页面后进行再次提交 二、防止防止表单重复提交的方式 1、利用JavaScript防止表单重复提交 (1)、用JavaScript控制Form表单只能提交一次... javascript"> var isCommitted = false; //表单是否已经提交标识,默认为false function dosubmit...(5)、提交后重定向到一个提交成功的页面 表单提交后跳转到另外一个成功页面。这样可以避免用户按F5导致的重复提交,浏览器也不会出现表单重复提交的警告,以及消除按浏览器前进和后退按导致的同样问题。...如果表单重复提交,那么数据库插入重复记录时,唯一约束能有效避免重复入库。

    2.2K20

    探索RocketMQ的重复消费和乱序问题

    前言 在之前的MQ专题中,我们已经解决了消息中间件的一大难题,消息丢失问题。 但MQ在实际应用中不是说保证消息不丢失就万无一失了,它还有两个令人头疼的问题:重复消费和乱序。...今天我们就来聊一聊这两个常见的问题,看看RocketMQ是如何解决这两个问题的。 为什么会重复消费 首先我们来聊一聊重复消费的问题,要解决一个问题最开始的一步当然是去查找问题发生的原因了。...如何解决重复消费 解决重复消费的关键就是引入幂等性机制,什么是幂等性机制呢?我们可以把它理解成,假如一个接口被重复调用,依然可以保证数据的准确性。...消息重试、延时消息、死信队列 解决完重复消费问题,我们来思考一种极端情况,比如某一时刻,消费者操作的数据库宕机了,这个时候消费者会发生异常,当然不能返回给MQ一个CONSUME_SUCCESS了,我们可以返回...总结 好了,到这里关于RocketMQ重复消费和乱序问题的产生原因和解决方案我们就介绍完了,同时也介绍了RocketMQ的重试机制、延时消息和死信队列。

    1.3K20

    探索RocketMQ的重复消费和乱序问题

    前言 在之前的MQ专题中,我们已经解决了消息中间件的一大难题,消息丢失问题。 但MQ在实际应用中不是说保证消息不丢失就万无一失了,它还有两个令人头疼的问题:重复消费和乱序。...今天我们就来聊一聊这两个常见的问题,看看RocketMQ是如何解决这两个问题的。 为什么会重复消费 首先我们来聊一聊重复消费的问题,要解决一个问题最开始的一步当然是去查找问题发生的原因了。...image.png 如何解决重复消费 解决重复消费的关键就是引入幂等性机制,什么是幂等性机制呢?我们可以把它理解成,假如一个接口被重复调用,依然可以保证数据的准确性。...消息重试、延时消息、死信队列 解决完重复消费问题,我们来思考一种极端情况,比如某一时刻,消费者操作的数据库宕机了,这个时候消费者会发生异常,当然不能返回给MQ一个CONSUME_SUCCESS了,我们可以返回...总结 好了,到这里关于RocketMQ重复消费和乱序问题的产生原因和解决方案我们就介绍完了,同时也介绍了RocketMQ的重试机制、延时消息和死信队列。

    1K10

    JavaWeb学习(1) 使用Session和Token防止表单重复提交

    那么我们的今天主题就是如何使用Session和Token防止表单重复提交 ---- 表单重复提交例子 在我们写网站的时候,肯定写过留言板的功能,但是肯定对重复提交留言的恶性行为没有进行一些安全措施。...Paste_Image.png ---- 如何进行防止表单重复提交 其实很简单的,我们只需要生成一个唯一的token,分别放进客户端的表单里和服务器的session中进行了。...当我们发起请求时,只需要判断session中的token(以下简称serverToken)和客户端表单里的token(以下简称clientToken)是否相等。...已经成功防止了表单重复提交不安全的行为了。 ? Paste_Image.png 发现的问题 写这边简文的时候,我也看到其他大牛写的博客。在底下的评论也发现了一个存在的问题。...就是打开2个上传图片的网页,在第一个网页上传到了照片,提示"上传成功"。然后在打开第二个网页再上传图片,就会提示"请不要重复提交"。这是什么问题造成的呢?

    1.4K30

    防止用户将表单重复提交的方法 原

    表单重复提交是在多用户Web应用中最常见、带来很多麻烦的一个问题。有很多的应用场景都会遇到重复提交问题,比如: 点击提交按钮两次。 点击刷新按钮。...使用浏览器后退按钮重复之前的操作,导致重复提交表单。 使用浏览器历史记录重复提交表单。 浏览器重复的HTTP请求。   几种防止表单重复提交的方法 1.禁掉提交按钮。...表单提交后使用JavaScript使提交按钮disable。这种方法防止心急的用户多次点击按钮。但有个问题,如果客户端把Javascript给禁止掉,这种方法就无效了。   ...这能避免用户按F5导致的重复提交,而其也不会出现浏览器表单重复提交的警告,也能消除按浏览器前进和后退按导致的同样问题。 3.在session中存放一个特殊标志。...在数据库里添加唯一约束或创建唯一索引,防止出现重复数据。这是最有效的防止重复提交数据的方法。

    2K20

    javascript表单之间的数据传递

    今天有朋友问我关于用javascript来进行页面各表单之间的数据传递的问题,我以前也写过,不过从来没有注意,今天总结了一下,希望能够给大家一些帮助,也帮助我总结以前学过,用过的知识。    ...一,最简单的就是同一个网页里的表单的数据传递。      举个实例,一个网页上有两个表单,每个表单里一个文本框,一个按钮。点按钮互相对操作对方的文本框的值。我们举的例子是把一个文本框付给另一个文本框。...,大家可能注意到了onclik的代码了,有两个函数,接下来就是javascript的代码了: javascript"> function ok() { document.form2...其实这个可以在原来的基础上进行一些扩展就可以了。关于如何创建弹出窗口,窗体里的表单的代码, 在这里就不多说了,现在在这里说一下如何操作父窗口的表单里的文本框的数据。....textfield.value }    三,第三种就是框架网页之间的表单的文本框之间数据传递.

    87430

    fastjson 重复引用和循环引用问题

    fastjson 由阿里巴巴那伙人使用Java语言编写,号称最快的JSON库 前两天遇到一个问题 后台的数据转化为json字符串后发送到前台出现了$ref字样的东西,后来明白了这是引用,在传输的数据中出现相同的对象时...,fastjson默认开启引用检测将相同的对象写成引用的形式....说到引用分为两种,重复引用和循环引用 重复引用 指一个对象重复出现多次 循环引用 指你心里有我,我心里有你(互相引用),这个问题比较严重,如果处理不好就会出现StackOverflowError异常 重复引用的解决方法...全局配置关闭 JSON.DEFAULT_GENERATE_FEATURE |= SerializerFeature.DisableCircularReferenceDetect.getMask(); 循环引用的解决方法...: 1.如果你前端用不到这个属性在该属性的get方法上加上注解@JSONField(serialize=false), 这样该属性就不会被序列化出来,这个也可以解决重复引用 2.修改表结构,出现循环引用了就是一个很失败的结构了

    2.6K40

    浅析JavaScript的用户登录表单——焦点事件

    在Web项目开发中,经常会在表单验证功能看到焦点事件。例如,文本框获取焦点改变文本框的颜色,文本框失去焦点检验输入的文本框的内容是否正确等。接下来,小编带大家一起来实现一个用户登录的表单!...检验id为user和pass的元素如果失去焦点,它的value值是不是为空。...五、总结 1.本文基于JavaScript基础,实现用户登录的功能。对每一个div层进行详解,让读者更好的理解。...2.在JavaScript中首先获取操作元素的对象,给指定元素添加失去焦点事件,之后,检验指定元素失去焦点,它的value值是否为空,检验表单是否为空。最后处理登录按钮的事件。...最后需要本文项目代码的小伙伴,请在公众号后台回复“焦点事件”关键字进行获取,如果在运行过程中有遇到任何问题,请随时留言或者加小编好友,小编看到会帮助大家解决bug噢!

    1.9K11
    领券