php页面防重复提交方法总结


Posted in PHP onNovember 25, 2013

1、提交按钮置disabled

      当用户提交后,立即把按钮置为不可用状态。这种用js来实现。

         提交前

        $("#submit").attr('disabled','true');
         $("#submit").val("正在提交,请稍等");

 

       ....................................................................................

    执行后,把按钮置为原来状态

      $('#submit ').removeAttr('disabled');
      $("#submit ").val("确定提交");

2、过期时间法

    思路:当用户提交按钮后生成一个token(每次业务提交token 为唯一值)存入session,并设置过期时间。当用户再此提交时,检测token是否一致且是否过期,若一致且没有过期,则认为提交了二次。当程序执行出错的时候,则需要清除存入session的值。见下面程序

function checkRepeatSubmit($uniqueid = '', $expire = 30) {
        $uniqueid = empty($uniqueid) ? Yii::app()->user->id . Yii::app()->user->name . Yii::app()->user->mihome : $uniqueid;
        $token = md5("wms_check_repeat" . $uniqueid);
        $time = time();
        if (isset($_SESSION['token']) && !empty($_SESSION['token']) && $_SESSION['token'] == $token && ($time - $_SESSION['expire_time'] < $expire)) {
            return false;
        } else {
            $_SESSION['token'] = $token;
            $_SESSION['expire_time'] = $time;
            //session写入的时候会等待整个页面加载完成,用此函数可以立即写入
            session_write_close();
            return true;
        }
    }
 //删除存入的值
   function cancelRepeatSubmit() {
        unset($_SESSION['token']);
        unset($_SESSION['expire_time']);
    }

3、token销毁法

思路:当页面进行加装的时候生成token,存在session中,并写在表单里。表单提交的时候随表单提交给服务端,服务端通过session存入的token与token进行比较,若相等,则销毁seesion中存入的token,当页面遭到二次提交的时候,由于存入session中的token不存在而报错。下面是代码

 /**
     * 第二种方案
     * 1、产生token,并存在session中
     * 2、随页面生成
     * 3、提交页面与session进行比对,成功后对session进行销毁
     * 4、第二次提交则不存在这个值而报错
     * @param type $uniqueid
     * @return type
     */
    function createToken($uniqueid) {
        $uniqueid = empty($uniqueid) ? Yii::app()->user->id . Yii::app()->user->name . Yii::app()->user->mihome : $uniqueid;
        $token = md5("wms_check2_repeat" . $uniqueid);
        $_SESSION['form_token'] = $token;
       ​session_write_close();

        return $token;
    }
    function checkToken($token) {
        if (!isset($_SESSION['form_token']) || empty($_SESSION['form_token']) || $_SESSION['form_token'] != $token) {
            return false;
        } else {
            unset($_SESSION['form_token']);
            return true;
        }
    }

上面总结了三种方法,个人感觉第一种跟第二种方法配合着用会达到更好的效果。第二种方法与第三种方法个人感觉第三种要有优势点。

第二种与第三种方法都是把token写在session中,这种方法好处是节省存储空间,但坏处是由于session是需要整个页面加载完毕才能写入,故当整个页面加载比较慢,且用户点击多次提交,可能由于session还没写入导致系统还认为是第一次输入。导致验证不起作用。好在php函数提供了一个牛逼的函数。   session_write_close(),可以立即把session写入,不用等待页面加载完成。同事对于session的存入也有很多种方法可以选择,可以存在redis,memcache或者数据库都可以的。

PHP 相关文章推荐
PHP 服务器配置(使用Apache及IIS两种方法)
Jun 01 PHP
PHP里的中文变量说明
Jul 23 PHP
深入PHP中的HashTable结构详解
Jun 13 PHP
PHP异常Parse error: syntax error, unexpected T_VAR错误解决方法
May 06 PHP
mac下Apache + MySql + PHP搭建网站开发环境
Jun 02 PHP
PHP常用技术文之文件操作和目录操作总结
Sep 27 PHP
PHP之sprintf函数用法详解
Nov 12 PHP
PHP 中 var_export、print_r、var_dump 调试中的区别
Jun 19 PHP
php获取手机端的号码以及ip地址实例代码
Sep 12 PHP
TP5.0框架实现无限极回复功能的方法分析
May 04 PHP
PHP实现随机发扑克牌
Apr 22 PHP
php使用自带dom扩展进行元素匹配的原理解析
May 29 PHP
php用header函数实现301跳转代码实例
Nov 25 #PHP
保存到桌面、设为桌面且带图标的PHP代码
Nov 19 #PHP
php使浏览器直接下载pdf文件的方法
Nov 15 #PHP
限制ckeditor上传图片文件大小的方法
Nov 15 #PHP
php ckeditor上传图片文件名乱码解决方法
Nov 15 #PHP
json的键名为数字时的调用方式(示例代码)
Nov 15 #PHP
php解析xml提示Invalid byte 1 of 1-byte UTF-8 sequence错误的处理方法
Nov 14 #PHP
You might like
php mssql 分页SQL语句优化 持续影响
2009/04/26 PHP
ie6 动态缩略图不显示的原因
2009/06/21 PHP
php通过排列组合实现1到9数字相加都等于20的方法
2015/08/03 PHP
十个PHP高级应用技巧果断收藏
2015/09/25 PHP
IE6/7/8/9不支持exec的简写方式
2011/05/25 Javascript
jQuery+css实现的时钟效果(兼容各浏览器)
2016/01/27 Javascript
js实现html table 行,列锁定的简单实例
2016/10/13 Javascript
Node.js中用D3.js的方法示例
2017/01/16 Javascript
js输入框使用正则表达式校验输入内容的实例
2017/02/12 Javascript
jquery实现图片上传前本地预览
2017/04/28 jQuery
jQuery菜单实例(全选,反选,取消)
2017/08/28 jQuery
JavaScript中数组常见操作技巧
2017/09/01 Javascript
Node使用Sequlize连接Mysql报错:Access denied for user ‘xxx’@‘localhost’
2018/01/03 Javascript
用vue2.0实现点击选中active其他选项互斥的效果
2018/04/12 Javascript
vue删除html内容的标签样式实例
2018/09/13 Javascript
微信小程序动态增加按钮组件
2018/09/14 Javascript
使用weixin-java-tools完成微信授权登录、微信支付的示例
2018/09/26 Javascript
如何通过setTimeout理解JS运行机制详解
2019/03/23 Javascript
Python获取运行目录与当前脚本目录的方法
2015/06/01 Python
TensorFlow Session使用的两种方法小结
2018/07/30 Python
Tensorflow使用支持向量机拟合线性回归
2018/09/07 Python
django之跨表查询及添加记录的示例代码
2018/10/16 Python
解决python flask中config配置管理的问题
2019/07/26 Python
Python解决pip install时出现的Could not fetch URL问题
2019/08/01 Python
Python使用xlrd实现读取合并单元格
2020/07/09 Python
CSS3 text-shadow实现文字阴影效果
2016/02/24 HTML / CSS
纯CSS3绘制打火机动画火焰效果
2016/07/18 HTML / CSS
德国箱包网上商店:koffer24.de
2016/07/27 全球购物
澳大利亚制造的蜡烛和扩散器:Glasshouse Fragrances
2018/05/20 全球购物
大学毕业感言50字
2014/02/07 职场文书
化妆品促销方案
2014/02/24 职场文书
互联网电子商务专业毕业生求职信
2014/03/18 职场文书
岗位聘任书范文
2014/03/29 职场文书
学习三严三实心得体会
2014/10/13 职场文书
运动会闭幕式主持词
2015/07/01 职场文书
JS的深浅复制详细
2021/10/16 Javascript