首页 > 后端开发 > PHP问题 > php如何避免多次提交

php如何避免多次提交

爱喝马黛茶的安东尼
发布: 2023-02-25 08:58:01
原创
2703 人浏览过

php如何避免多次提交

下面的情况就会导致表单重复提交:

·点击提交按钮两次。

·点击刷新按钮。

·使用浏览器后退按钮重复之前的操作,导致重复提交表单。

·使用浏览器历史记录重复提交表单。

·浏览器重复的HTTP请求。

·网页被恶意刷新。

下面是几种解决办法:

一、利用js设置按钮点击后变成灰色

<form name=form1 method=”POST” action=”/” target=_blank>
<p>
<input type=”text” name=”T1″ size=”20″>
<input type=”button” value=”提交” οnclick=”javascript:{this.disabled=true;document.form1.submit();}”>
</p>
</form>
登录后复制

点击完按钮之后变成灰色就不能点击了,用户需要再次提交表单的话就要刷新页面之后重新填写数据再提交了。

相关推荐:《php教程

二、利用session

在session中放一个特殊标志。当表单页面被请求时,生成一个特殊的字符标志串,存在session中,同时放在表单的隐藏域里。接受处理表单数据时,检查标识字串是否存在,并立即从session中删除它,然后正常处理数据。

如果发现表单提交里没有有效的标志串,这说明表单已经被提交过了,忽略这次提交。

这使你的web应用有了更高级的XSRF保护。

加载提交的页面时候,生成一个随机数:

$code = mt_rand(0,1000000);
登录后复制

存储在表单的隐藏输入框中:

< input type=”hidden” name=”code” value=””>
登录后复制

在接收页面的PHP代码如下:

<?php 
session_start(); 
if(isset($_POST[‘code&#39;])) {
if($_POST[‘code&#39;] == $_SESSION[‘code&#39;]){
// 重复提交表单了
}else{
$_SESSION[‘code&#39;] =$_POST[‘code&#39;]; //存储code
}
}?>
登录后复制

三、利用cookies

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

if(isset($_POST[‘submit&#39;])){ 
setcookie(“tempcookie”,””,time()+30); 
header(“Location:”.$_SERVER[PHP_SELF]);exit(); 
} 
if(isset($_COOKIE[“tempcookie”])){ 
setcookie(“tempcookie”,””,0);echo “您已经提交过表单”; 
}
登录后复制

四、利用header函数跳转

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

if (isset($_POST[‘submit&#39;])) {
header(‘location:success.php&#39;);//处理数据后,转向到其他页面
 
}
登录后复制

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

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

六、Post/Redirect/Get模式

在提交后执行页面重定向,这就是所谓的Post-Redirect-Get (PRG)模式。简而言之,当用户提交了表单后,你去执行一个客户端的重定向,转到提交成功信息页面。

if (isset($_POST[‘action&#39;]) && $_POST[‘action&#39;] == ‘submitted&#39;) {
//处理数据,如插入数据后,立即转向到其他页面
header(&#39;location:submits_success.php&#39;);
}
登录后复制

以上是php如何避免多次提交的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板