1. 云栖社区>
  2. PHP教程>
  3. 正文

php 解决和避免form表单重复提交的方法

作者:用户 来源:互联网 时间:2017-12-01 12:49:29

表单方法

php 解决和避免form表单重复提交的方法 - 摘要: 本文讲的是php 解决和避免form表单重复提交的方法, 转载于:http://www.hlmblog.com/183.html 在提交表单的时候,可能遇到网速等导致页面突然加载变慢,用户重复地点击提交按钮,将在数据库产生多条数据,导致不可控情况。 比如下面的情况就会导致表单重复提交:点击提交

转载于:http://www.hlmblog.com/183.html

在提交表单的时候,可能遇到网速等导致页面突然加载变慢,用户重复地点击提交按钮,将在数据库产生多条数据,导致不可控情况。

比如下面的情况就会导致表单重复提交:
点击提交按钮两次。
点击刷新按钮。
使用浏览器后退按钮重复之前的操作,导致重复提交表单。
使用浏览器历史记录重复提交表单。
浏览器重复的HTTP请求。
网页被恶意刷新。

下面是几种解决的方法:
一:利用js设置按钮点击后变成灰色

$(document).ready(function(){  $(input:submit).click(){      setTimeout(function(){obj.disabled=true;},100)  };});

二:利用session

表单隐藏域中存放session(表单被请求时生成的标记)。

采用此方法在接收表单数据后,检查此标志值是否存在,先进行删除,然后处理数据; 若不存在,说明已提交过,忽略本次提交。

//服务端生成随机数存入session, 分配至表单页$data['sess_id'] = $_SESSION['sid'] = mt_rand(1000, 9999);$this->load->view('form', $data);//表单页隐藏域存放此session值<input type="hidden" name="sid" value="<?=$sess_id; ?>">//处理if($_POST['sid'] != '' && $_POST['sid'] == $_SESSION['sid']){ unset($_SESSION['sid']); echo '处理数据';}else{ echo '已提交过表单';}

三:利用cookies
原理和session差不多,但是cookies一旦用户浏览器禁用cookies,这功能就失效了

if(isset($_POST['submit'])){    setcookie("tempcookie","",time()+30);      header("Location:".$_SERVER[PHP_SELF]);exit();  }if(isset($_COOKIE["tempcookie"])){      setcookie("tempcookie","",0);echo "您已经提交过表单";  }

四:利用header函数跳转

一旦用户点击提交按钮,处理完数据后跳到其他页面

if (isset($_POST['submit'])) {   header('location:success.php');//处理数据后,转向到其他页面}

五:利用数据库来添加约束

直接在数据库里添加唯一约束或创建唯一索引,一旦发现用户重复提交了,直接抛出警告或者提示,
或者只处理第一次提交的数据,这是最直接有效的方法,要求前期的数据库设计和架构要考虑周全

以上是云栖社区小编为您精心准备的的内容,在云栖社区的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索表单 方法 ,以便于您获取更多的相关知识。

稳定可靠、可弹性伸缩的在线数据库服务,全球最受欢迎的开源数据库之一

6款热门基础云产品6个月免费体验;2款产品1年体验;1款产品2年体验

弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率

开发者常用软件,超百款实用软件一站式提供