如何防止表单重复提交
如何防止表单重复提交
如何防止表单重复提交一、有很多的应用场景都会遇到重复提交问题,比如:
1、点击提交按钮两次。
2、点击刷新按钮。
3、使用浏览器后退按钮重复之前的操作,导致重复提交表单。
4、使用浏览器历史记录重复提交表单。
5、浏览器重复的 HTTP 请求。
二、防止表单重复提交的方法
1、禁掉提交按钮
表单提交后使用 Javascript 使提交按钮disable。这种方法防止心急的用户多次点击按钮。但有个问题,如果客户端把 Javascript 给禁止掉,这种方法就无效了。
2、Post/Redirect/Get 模式
在提交后执行页面重定向,这就是所谓的 Post-Redirect-Get (PRG)模式。简言之,当用户提交了表单后,你去执行一个客户端的重定向,转到提交成功信息页面。
这能避免用户按 F5 导致的重复提交,而其也不会出现浏览器表单重复提交的警告,也能消除按浏览器前进和后退按导致的同样问题。
3、在 session 中存放一个特殊标志
当表单页面被请求时,生成一个特殊的字符标志串,存在 session 中,同时放在表单的隐藏域里。接受处理表单数据时,检查标识字串是否存在,并立即从 session 中删除它,然后正常处理数据。如果发现表单提交里没有有效的标志串,这说明表单已经被提交过了,忽略这次提交。这使你的 web 应用有了更高级的 XSRF 保护。
4、使用Cookie处理
使用Cookie记录表单提交的状态,根据其状态可以检查是否已经提交表单。
5、在数据库里添加约束
在数据库里添加唯一约束或创建唯一索引,防止出现重复数据。这是最有效的防止重复提交数据的方法。
- vue elementui 公共列表组件(Vue Element-ui表单校验规则实现)
- vue表单上传图片数据(vue-cropper插件实现图片截取上传组件封装)
- javascript如何获取后台数据(JavaScript实现异步获取表单数据)
- js获取子表单所有数据(JavaScript实现异步提交表单数据)
- laravel常用的辅助函数介绍(Laravel框架表单验证操作实例分析)
- element-ui如何关闭表单验证(ElementUI实现el-form表单重置功能按钮)
- python怎么实现链表(Python实现数据结构线性链表单链表算法示例)
- 前端表单验证(AmazeUI的JS表单验证框架实战示例分享)
- 如何禁止按回车键提交表单
- 如何获取html5表单中的元素的值(html5 datalist 选中option选项后的触发事件)
- 织梦文章发布页如何增加表单(织梦CMS列表页只显示一篇文章的解决办法)
- 检查表单数据是否改变
- php 处理html表单(PHP使用HTML5 FormData对象提交表单操作示例)
- php表单上传文件功能(PHP单文件上传原理及上传函数的封装操作示例)
- html5新的表单元素新的特性(HTML5表单验证特性知识点小结)
- thinkphp表单提交不到数据(ThinkPHP5.1表单令牌Token失效问题的解决)
- 散文 八月再见,九月,我在风中等你(散文八月再见九月)
- 8月再见 9月你好(8月再见)
- 魔兽世界 设计师爆料,原始版本并无PVP,跨阵营属于返璞归真(魔兽世界设计师爆料)
- 吐槽完《弧光大作战》之后,我们和设计师聊了聊魔兽首款手游的立项初衷和未来(吐槽完弧光大作战之后)
- 魔兽争霸3自定义战役少年杰雷 2(魔兽争霸3自定义战役少年杰雷)
- 今日菜价 芥兰涨幅最高 1.33 ,花菜降幅最高 3.10(今日菜价芥兰涨幅最高)
热门推荐
- laravel模块教程(Laravel框架创建路由的方法详解)
- python中list用法(Python数据类型之List列表实例详解)
- sleep线程不安全(当master down掉后,pt-heartbeat不断重试会导致内存缓慢增长的原因及解决办法)
- mysqlupdate语句(MySQL将select结果执行update的实例教程)
- 织梦dedecms的时间调用标签(dedecms/织梦专题节点列表内容实现分页的方法介绍)
- 阿里云linux配置(阿里云ESC linux服务器日常安全运维常用命令)
- linux查python进程(linux查找当前python解释器的位置方法)
- JavaScript 阻止超链接跳转的操作方法(多种写法)(JavaScript 阻止超链接跳转的操作方法多种写法)
- reactnative零基础入门到项目实战(用React Native制作一个简单的游戏引擎)
- jquery on绑定多个事件
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9