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


Posted in PHP onAugust 31, 2016

前言

为什么要避免form表单被重复提交呢?因为我们不想让我们的服务器重复处理没必要的数据,同时我们也是避免我们的数据库产生重复的数据,避免表单重复提交也是让我们的网站更安全的一种表现。

先看一下有哪些情况下回导致表单重复提交呢,知道哪些情况下可能会出现表单重复提交就可以从根源处理表单重复提交的情况了。

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

      点击提交按钮两次。

      点击刷新按钮。

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

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

      浏览器重复的HTTP请求。

      网页被恶意刷新。

下面是几种解决办法:

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

<form name=form1 method=”POST” action=”/” target=_blank>

<p>

<input type=”text” name=”T1″ size=”20″>

<input type=”button” value=”提交” onclick=”javascript:{this.disabled=true;document.form1.submit();}”>

</p>

</form>

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

二:利用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'])) {

if($_POST[‘code'] == $_SESSION[‘code']){

// 重复提交表单了

}else{

$_SESSION[‘code'] =$_POST[‘code']; //存储code

}

}?>

三:利用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');//处理数据后,转向到其他页面

}

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

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

六:Post/Redirect/Get模式。

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

if (isset($_POST[‘action']) && $_POST[‘action'] == ‘submitted') {

//处理数据,如插入数据后,立即转向到其他页面

header('location:submits_success.php');

}

总结

以上就是关于PHP解决和避免form表单重复提交的几种方法,通过以上几种方法就能避免用户按F5导致的重复提交,而其也不会出现浏览器表单重复提交的警告,也能消除按浏览器前进和后退按导致的同样问题。希望这篇文章对大家的学习和工作能带来一定的帮助。

PHP 相关文章推荐
php 服务器调试 Zend Debugger 的安装教程
Sep 25 PHP
PHP中文处理 中文字符串截取(mb_substr)和获取中文字符串字数
Nov 10 PHP
PHP页面间参数传递的四种方法详解
Jun 09 PHP
php中函数前加&amp;符号的作用分解
Jul 08 PHP
Yii实现MySQL多数据库和读写分离实例分析
Dec 03 PHP
php解析xml 的四种简单方法(附实例)
Jul 11 PHP
php getcwd与dirname(__FILE__)区别详解
Sep 24 PHP
利用php生成验证码
Feb 23 PHP
详解php协程知识点
Sep 21 PHP
PHP压缩图片功能的介绍
Mar 21 PHP
thinkphp5 模型实例化获得数据对象的教程
Oct 18 PHP
Thinkphp极验滑动验证码实现步骤解析
Nov 24 PHP
PHP Callable强制指定回调类型的方法
Aug 30 #PHP
thinkphp配置文件路径的实现方法
Aug 30 #PHP
总结PHP删除字符串最后一个字符的三种方法
Aug 30 #PHP
功能强大的php文件上传类
Aug 29 #PHP
功能强大的PHP发邮件类
Aug 29 #PHP
微信网页授权(OAuth2.0) PHP 源码简单实现
Aug 29 #PHP
Laravel 5.3 学习笔记之 错误&amp;日志
Aug 28 #PHP
You might like
关于文本留言本的分页代码
2006/10/09 PHP
php生成随机数或者字符串的代码
2008/09/05 PHP
phpmailer发送gmail邮件实例详解
2013/06/24 PHP
PHP防止刷新重复提交页面的示例代码
2015/11/11 PHP
PHP实现带重试功能的curl连接示例
2016/07/28 PHP
自制PHP框架之模型与数据库
2017/05/07 PHP
php过滤htmlspecialchars() 函数实现把预定义的字符转换为 HTML 实体用法分析
2019/06/25 PHP
PHP框架实现WebSocket在线聊天通讯系统
2019/11/21 PHP
javascript下阻止表单重复提交、防刷新、防后退
2007/08/17 Javascript
jquery 中多条件选择器,相对选择器,层次选择器的区别
2012/07/03 Javascript
ExtJs中gridpanel分组后组名排序实例代码
2013/12/02 Javascript
在JavaScript中构建ArrayList示例代码
2014/09/17 Javascript
jquery实现submit提交表单
2015/02/03 Javascript
jQuery点缩略图弹出层显示大图片
2015/02/13 Javascript
jQuery选择器源码解读(六):Sizzle选择器匹配逻辑分析
2015/03/31 Javascript
jQuery固定元素插件scrolltofixed使用指南
2015/04/21 Javascript
浅析Node.js的Stream模块中的Readable对象
2015/07/29 Javascript
Javascript简写条件语句(推荐)
2016/06/12 Javascript
微信小程序 教程之注册页面
2016/10/17 Javascript
微信小程序 request接口的封装实例代码
2017/04/26 Javascript
Bootstrap模态框插入视频的实现代码
2017/06/25 Javascript
Angularjs 手写日历的实现代码(不用插件)
2017/10/18 Javascript
ionic3双击返回退出应用的方法
2019/09/17 Javascript
小程序双头slider选择器的实现示例
2020/03/31 Javascript
[03:11]完美世界DOTA2联赛PWL DAY8集锦
2020/11/09 DOTA
python显示天气预报
2014/03/02 Python
ubuntu 18.04搭建python环境(pycharm+anaconda)
2019/06/14 Python
pyecharts动态轨迹图的实现示例
2020/04/17 Python
python实现二分类和多分类的ROC曲线教程
2020/06/15 Python
tensorflow 大于某个值为1,小于为0的实例
2020/06/30 Python
英国马莎百货官网:Marks & Spencer
2016/07/29 全球购物
应征英语教师求职信
2013/11/27 职场文书
2014年机关植树节活动方案
2014/02/27 职场文书
镇创先争优活动总结
2014/08/28 职场文书
高三英语教学计划
2015/01/23 职场文书
引用计数法和root搜索算法以及JVM中判定对象需要回收的方法
2022/04/19 Java/Android