如题,在不使用验证码的情况下!

回复内容:

如题,在不使用验证码的情况下!

所有“通过前台JS,约束提交行为本身不会重复发生”的答案都是彻底错误的。

弱网络时如果POST请求到达了服务器响应却没回去,此时客户端报浏览器原生的超时错误,访客按F5重发,你的JS如之奈何?!

JS阻止重复点击按钮,仅仅是“锦上添花”的体验改进而已,根本称不上“防重复提交”的可靠方案。事实上我们也根本做不到“防止用户重复提交”——HTTP请求的到达能拦的了吗?这个需求的本质是:如何让重复提交的内容能够被识别出来(从而不被重复处理)。

重复提交的鉴别,无非两种思路:

比对内容相同的提交是否重复出现。

为每次提交标号,比对相同编号的提交是否重复出现。

而其中(1)又是等同于(2)的。因为提交不可能全量比较,只可能计算一个哈希值(MD5等)去比,这样无非就是依赖提交的内容做了一个标号。

HTTP协议是无状态的,不能从HTTP协议本身下手,所以自然要在业务层加上这个标号。

考虑清楚前提,办法就容易了。用种种手段把表单标上号就可以。不限于以下方法:

服务器下发表单时,在表单里附加一个毫秒时间戳或唯一ID

客户端JS在表单内,插入点按提交按钮的时间戳,以及浏览器的信息

服务器端收到表单时,对表单的内容做哈希签名并缓存

有些业务逻辑天生就是防重复的。例如订单的状态流转,一般都是单向、不重复且不可逆的。此时要充分利用业务逻辑,尽量在直接回弹不合法请求的同时,就把重复提交顺手一起干掉。

后端生成token,保存数据前验证

楼上说得都很好了,补充下,除了使用token进行校验外,还可以使用POST-Redirect-GET(PRG)的方式——最后呈现给用户的是一个GET的页面,即使用户按F5刷新页面也不会导致重复提交表单。

参考一下:表单令牌

PHP生成表单时设置一个token隐藏域,提交后JS则可以辅助把提交按钮设为不可点击.

提交表单时进行验证,相同则写入数据库并生成新的token.

token生成算法,比如:

$token = sha1(uniqid(mt_rand(), true));

uniqid获取一个带前缀(mt_rand),末尾带熵(true),基于当前时间微秒数的唯一编号.mt_rand用于生成更好的随机数.

作为一名Python程序猿,使用Django框架时,直接在模板里面,在

里面直接加上{% csrf_token %}

在第一次提交之后设置一定时间才能提交第二次,javascript里面有一个叫做debounce的可以应用到你得场景,

你可以把你提交的动作放到debounce里面,例如:

'use strict';

var debounce = function(func, timeout) {

var timer;

return function() {

var _this = this;

var args = Array.prototype.slice.call(arguments);

clearTimeout(timer);

timer = setTimeout(function() {

func.apply(_this, args);

}, timeout);

};

};

这样当你再调用post的提交方法submit()的时候,

var debounced = debounce(submit, 100);

debounced();

debounced();

debounced();

debounced();

它只会提交一次。

1、header地址重定向

2、JS跳转其他页面

3、设置Token并验证

做一个令牌吧,当正在处理数据时,令牌为false,不能提交;当无数据处理时,令牌为true,提交处理数据。

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

php post可重复提交了,如何防止 POST 数据重复提交!相关推荐

  1. mysql sum 重复计算_mysql join sum时数据重复问题及解决方案

    当我们使用mysql的join功能从多张表中取出数据并使用sum分别对取出的数据求和时 会发现sum出来的值是不对的,往往是正确值的整数倍 为什么会出现这样的情况呢 复现 假设有两张表:user_bu ...

  2. 数据重复插入问题及解决方案

    本文为joshua317原创文章,转载请注明:转载自joshua317博客 https://www.joshua317.com/article/25 1.问题背景 某天客户反馈说,有一条一模一样的数据 ...

  3. 致远个性化之--明细表数据重复判断,并显示重复数据

    需求 有业务需求,想实现明细表的数据重复提示以及显示是哪些数据重复: 实现 1.明细表数据重复提示 明细表的数据重复提示,致远表单自带有明细表公式,可以直接进行校验以及提示:如下图: 点击表单的校验规 ...

  4. java怎么防止表单重复提交_如何防止表单重复提交

    在平时开发中,如果网速比较慢的情况下,用户提交表单后,发现服务器半天都没有响应,那么用户可能会以为是自己没有提交表单,就会再点击提交按钮重复提交表单,我们在开发中必须防止表单重复提交. 一.表单重复提 ...

  5. 【重复提交表单】表单重复提交的三种情况,解决办法

    引入 看一个重复提交表单的例子 F12可以看到,请求体中的参数在刷新页面之后仍然保留,因此每一次刷新页面,都会把现有的请求体中的表单数据提交一次到服务器,而接收的页面还是insert.jsp,于是造成 ...

  6. java mysql防重复提交_防止数据重复提交的6种方法(超简单)!

    有位朋友,某天突然问磊哥:在 Java 中,防止重复提交最简单的方案是什么? 这句话中包含了两个关键信息,第一:防止重复提交:第二:最简单. 于是磊哥问他,是单机环境还是分布式环境? 得到的反馈是单机 ...

  7. java mvc中重复提交表单,spring mvc 防止重复提交表单的两种方法,推荐第二种

    第一种方法:判断session中保存的token 比较麻烦,每次在提交表单时都必须传入上次的token.而且当一个页面使用ajax时,多个表单提交就会有问题. 注解Token代码: package c ...

  8. form表单用js提前执行函数若不成功则不提交_面试必会的重复提交 8 种解决方案!...

    重复提交看似是一个小儿科的问题,但却存在好几种变种用法.在面试中回答的好,说不定会有意想不到的收获!现把这 8 种解决方案分享给大家! 1.什么是幂等 在我们编程中常见幂等 select查询天然幂等 ...

  9. 最简单的6种防止数据重复提交的方法!(干货)

    有位朋友,某天突然问磊哥:在 Java 中,防止重复提交最简单的方案是什么? 这句话中包含了两个关键信息,第一:防止重复提交:第二:最简单. 于是磊哥问他,是单机环境还是分布式环境? 得到的反馈是单机 ...

最新文章

  1. 【 MATLAB 】randn,rand,randi 之间的区别?
  2. 【Shall脚本】定时在线备份上传
  3. 深入理解C指针之三:指针和函数
  4. 编写python程序 兀 3_帮忙写一个简单的python程序π_π 要求就是图上的那样 其实挺简单的但我就是写不出来。拜托了,...
  5. git 修改远程仓库源
  6. Facebook与Google的互联网霸主争夺战
  7. 「leetcode」51. N皇后【回溯算法】详细图解!
  8. c# winform gridview 动态按钮_C#窗体Winform,使用实时图表:折线图、柱状图
  9. 使用X-Scan进行漏洞扫描的基本操作演示
  10. word html 预览 打印出来,word预览时文字在表格中,打印出来却没有.doc
  11. apache启动服务失败
  12. WIFI热点软件测试,用手机WiFi热点已OUT 华为随行WiFi Plus评测
  13. 什么是 P = NP 问题?
  14. CentOS 7 安全加固、检测、审计
  15. mysql字符串类型建立全文索引
  16. 长方形图片html圆形,css实现圆角矩形、半圆、圆形效果—border-radius使用详解
  17. 日本NTT Yamamoto教授荣获2022年兰姆奖
  18. PHPMyWind支持Word导入
  19. windows找不到文件常见问题
  20. python无法启动此程序丢失zlib.dll_关于winserver2012运行c++程序缺少dll的理由

热门文章

  1. 来学学数据分析吧(二)第一章 预测和关联数量特征
  2. 芯盾时代:致力于身份认证安全的领军者
  3. 2017 必备的八款最佳反勒索软件工具
  4. 翻译 | CSS网格(CSS Grid)布局入门
  5. 九个Console命令,让js调试更简单
  6. flume自定义Interceptor
  7. RFC 4303--ESP
  8. Error: No module named books
  9. 如何使用资源和样式调整控件外观
  10. Furein平台-比特币现金晋级毕竟在吵什么