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

表单提交原理_防止表单重复提交

1.HTTP是如何提交表单的 标签的属性enctype设置以何种编码方式提交表单数据。...它只处理表单域里的value属性值,采用这种变法方式的表单会将表单域的值处理成URL方式。...text/plain: 这种方式当表单的action属性值为mailto:URL的形式比较方便,这种方式主要适用于直接通过表单发送邮件。...正如前面所说的,表单提交表单,如果采用默认编码方式,文件的内容是不会被提交的。要提交文件内容要采用multipart/form-data编码方式,这需要在服务器端从提交的二进制流中读取文件内容。...Content-Disposition: form-data; name=”buttom” 上传 ——WebKitFormBoundaryQqpAxgR2Pgik6uyY– 可以看到提交表单数据是混合了所有请求参数的数据

5.4K20

如何防止表单重复提交

问题 在看Java Web 深入分析, 看到表单重复提交问题一节, 如下描述如何解决问题: 要防止表单重复提交, 就要标识用户的每一次访问请求, 使得每一次访问对服务端来说都是唯一的....为了标识用户的每次访问请求, 可以在用户请求一个表单,增加一个隐藏的表单项, 这个表单项的值每一次都是唯一的token....但是让我迷惑的是: 访问服务器获得唯一的token标识, 然后提交带上这个标志, 服务器检测是否和自己Session中的内容一致. 为什么这样就可以防止重复提交?...我提交的第二次, 第三次还是带有相同的token啊, 服务器检测Session中的内容应该还是一致的. 为什么可以防止重复提交?...就是说当服务器第一次收到客户端提交, Session中是能检测到token的, 然后准备处理, 应该先移除Session中的指定token.

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

实战之防止表单重复提交

防止重复提交 对于防止重复提交,最简单也最不安全的做法相信大家也都经历过,前端一个请求发送后立即禁用掉按钮,这里咱们来讨论一下后端对防止重复提交的处理方式。...主要针对非分布式环境下防止重复提交与分布式环境下的防止重复提交。一般分布式环境下也可以通过网关路由的方式将同一个用户的请求路由到一个实例上处理。...单进程内的防止重复提交 单个进程内防止重复提交可以选取的方式有很多种,因为并不是每一个接口都需要做防止重复提交的校验,所以java中通常采用注解+拦截器的方式来实现。...this.code = code; } public int getCode() { return code; } } } 每个有效用户访问...= null) { sessionIdMap.remove(key, key); } } 进程内防止重复提交的特点很明显,就是构建一个锁池,每个需要防止重复提交的请求需要来池中获取锁

2.8K30

js – form表单提交刷新

大家已经发现了, 当我们点击submit提交form表单的时候, 他会刷新一次, 如果不想它刷新的话有下面两种方法: 利用iframe 我们可以利用一个隐藏的iframe来实现, 主要是我们把提交目标放到一个隐藏的...iframe里, 然后让iframe提交数据 (ps: 这个未实测, 仅仅是网上提供的, 我记录一下...." name="the_iframe" style="display:none;"> 利用onsubmit事件 我们还可以绑定onsubmit事件(用jq的话是submit()), submit...按钮效果触发之前我们就把数据提交了, 然后我们return false(让submit这次的点击触发事件失效, 否则表单又会提交一次, 并且刷新页面) 我们可以这样: ====== 如果你用原生js的话...我们绑定onsubmit的时候是把return false放进onsubmit后面的调用函数内的, 这样子如果你的函数出现了错误, 将不会继续执行到函数最后’return false’这里, 还是会出现刷新的现象

14.3K10

form表单如何提交数据(表单提交请求默认方式)

Form表单提交数据的几种方式 一、submit提交 form标签中添加Action(提交的地址)和method(post),且有一个submit按钮()就可以进行数据的提交...这种默认的提交方式,一般会进行页面的跳转(不成功跳转到当前页面)。而有时候我们是对弹出框进行数据提交的,希望提交成功则关闭弹出框并刷选父页面,失败则提示失败原因,且弹出框不关闭。...二、Ajax提交form表单 $(‘#documentForm’).submitForm({ url: “/Document/SubmitDocumentCreate”,...$(‘#ff’).form(‘submit’, { url:…, onSubmit: function(){ //进行表单验证 //如果返回false阻止提交 }, success:function...(data){ alert(data) } }); 四、form表单提交附件 需要设定form的enctype=”multipart/form-data”并且添加<input type=’file

4.4K10

php防止表单重复提交实例讲解

公司后台做表单提交,一是自己员工用,二是 html 自己来写的,没有验证表单重复提交,结果出错了。写出来记录下以便提醒自己,时刻不能疏忽。 解决方法 其实方法有很多种,只举例几个简单的来说说。...框架 很多框架都有防止重复提交的功能,大家应该都有了解,这里不再赘述。 前端 原理很简单,用户点击提交之后,使用 JS 将提交按钮置灰即可。...后端 也就是使用 PHP 进行验证,当然不局限以下几种 Cookie 用户提交表单到后端, Cookie 中做标记,指定时间内重复提交无效。但是用户禁用 Cookie 这个方法就失效了。 <?...', time(), time() + 30); Session 展示表单页面的时候,生成随机数,同时存储 Session 中以及表单隐藏域中。...= $_SESSION['formFlag']) { exit('error'); } // 处理数据 unset($_SESSION['formFlag']); 上面就是本次介绍PHP防止重复提交表单的全部内容

2.6K20

表单提交后端如何接收数据_html怎么接收表单提交的内容

= require("querystring"); //创建服务器 var server = http.createServer(function (req,res) { //如果你访问的地址是表单提交的这个地址...,并且表单提交的方式是POST // toLowerCase即将字母都转为小写 //可能接受一小段之后就去给别人服务了,放置过大的表单阻塞了整个进程 if(req.url == "/dopost"&&req.method.toLowerCase...util = require(“util”); //创建服务器 var server = http.createServer(function (req,res) { //如果你访问的地址是表单提交的这个地址...,并且表单提交的方式是POST // toLowerCase即将字母都转为小写 //可能接受一小段之后就去给别人服务了,放置过大的表单阻塞了整个进程 if(req.url == “/dopost.../uploads"; 将表单提交的文件存储到一个名为uploads的文件夹中 加强版:现在我们希望图片等文件上传之后,能够按照我们希望的格式存储下来: 我们可以看到输出的files对象中,有path

5.8K20

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

2.场景二:提交表单成功之后用户再次点击刷新按钮导致表单重复提交 ? 3.场景三:提交表单成功之后点击后退按钮回退到表单页面再次提交 ? 表单重复提交的弊端 下面通过一个简单的示例进行说明。...显然,从演示结果来看,如果出现表单重复提交,将会导致相同的数据被重复插入到数据库中。实际上,这是不应该发生的。 如何避免重复提交表单 关于解决表单重复提交,分为在前端拦截和服务端拦截2种方式。...在前端拦截虽然可以解决场景一的表单重复提交问题,但是针对场景二(刷新)和场景三(后退重新提交)的表单重复提交是无能为力的。 ?...2.服务器端对表单重复提交进行拦截 服务器端拦截表单重复提交的请求,实际上是通过服务端保存一个token来实现的,而且这个服务端保存的token需要通过前端传递,分三步走: 第一步:访问页面服务端保存一个随机..."> 第三步:提交表单服务端通过检查token来判断是否为重复提交表单请求 public class DoFormServlet extends

4.6K20

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

一、表单重复提交的常见应用场景 网络延迟的情况下用户多次点击submit按钮导致表单重复提交 用户提交表单后,点击【刷新】按钮导致表单重复提交(点击浏览器的刷新按钮,就是把浏览器上次做的事情再做一次,因为这样也会导致表单重复提交...) 用户提交表单后,点击浏览器的【后退】按钮回退到表单页面后进行再次提交 二、防止防止表单重复提交的方式 1、利用JavaScript防止表单重复提交 (1)、用JavaScript控制Form表单只能提交一次..."; //返回true让表单可以正常提交 return true; } (3)、验证码 页面上添加验证码,不管验证输入正确与否,提交后均刷新验证码。...用户页面上提交带着这个token一块提交到服务端,服务端通过比对token的值。...如果表单重复提交,那么数据库插入重复记录,唯一约束能有效避免重复入库。

2.1K20

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

比如当他点击提交表单,服务器处理比较慢, 页面上没有任何反应,他会迫不及待地再点击几次,这样就会产生重复数据或者报错,或者他会刷新一下再次提交。...对于如何处理重复提交,一般教科书上都有点明,不外乎是js代码中增加限制或者通过session来处理。...session处理,就是访问表单提交,服务器端生成一个随机序列,存储session中,并传递到客户端,用户提交,连同这个序列一起传递到服务器,后端程序会判断这两个序列是否一致,如果一致,表明是第一次提交...但是多服务器多用户的场景下,以上方法也都会失效,多服务器场景下,session存在于每台服务器中,请求是通过负载均衡机制分配到各台服务器上的,要通过session防止重复提交,必须有一套定向分派请求或者...,当值大于1,表示资源已在处理中,后续请求被抛弃或处于等待状态,待处理完毕,将值重新设为0,表示资源已解锁可用。这是借助redis缓存实现的类加锁机制,解决多服务器多用户场景下请求重复提交的情况。

1.8K80
领券