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 相关文章推荐
真正面向对象编程:PHP5.01发布
Oct 09 PHP
模仿OSO的论坛(五)
Oct 09 PHP
一个好用的分页函数
Nov 16 PHP
PHP中MVC模式的模板引擎开发经验分享
Mar 23 PHP
smarty内置函数config_load用法实例
Jan 22 PHP
thinkphp如何获取客户端IP
Nov 03 PHP
PHP自定义图片缩放函数实现等比例不失真缩放的方法
Aug 19 PHP
php+ajax+json 详解及实例代码
Dec 12 PHP
PHP学习笔记之session
May 06 PHP
Laravel中为什么不使用blpop取队列详析
Aug 01 PHP
深入解析PHP底层机制及相关原理
Dec 11 PHP
PHP 时间处理类Carbon
May 20 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 INI配置文件的解析实现分析
2011/01/04 PHP
PHP_NETWORK_GETADDRESSES: GETADDRINFO FAILED问题解决办法
2014/05/04 PHP
PHP连接MSSQL方法汇总
2016/02/05 PHP
JavaScript中的prototype和constructor简明总结
2014/04/05 Javascript
javaScript中slice函数用法实例分析
2015/06/08 Javascript
jQuery插件EasyUI校验规则 validatebox验证框
2015/11/29 Javascript
js格式化输入框内金额、银行卡号
2016/02/01 Javascript
js修改onclick动作的四种方法(推荐)
2016/08/18 Javascript
详解Vue整合axios的实例代码
2017/06/21 Javascript
Vue v2.5 调整和更新不完全问题
2017/10/24 Javascript
关于vue的语法规则检测报错问题的解决
2018/05/21 Javascript
Vue.JS实现垂直方向展开、收缩不定高度模块的JS组件
2018/06/19 Javascript
解决使用bootstrap的dropdown部件时报错:error:Bootstrap dropdown require Popper.js问题
2018/08/30 Javascript
vue完成项目后,打包成静态文件的方法
2018/09/03 Javascript
Layui弹出层 加载 做编辑页面的方法
2019/09/16 Javascript
转换layUI的数据表格中的日期格式方法
2019/09/19 Javascript
jQuery实现简易聊天框
2020/02/08 jQuery
利用Vue实现简易播放器的完整代码
2020/12/30 Vue.js
[01:04:09]DOTA2-DPC中国联赛 正赛 iG vs VG BO3 第二场 2月2日
2021/03/11 DOTA
Python端口扫描简单程序
2016/11/10 Python
Python实现字符串反转的常用方法分析【4种方法】
2017/09/30 Python
Python 实现引用其他.py文件中的类和类的方法
2018/04/29 Python
python和shell监控linux服务器的详细代码
2018/06/22 Python
python对数组进行排序,并输出排序后对应的索引值方式
2020/02/28 Python
python构造IP报文实例
2020/05/05 Python
python 读取串口数据的示例
2020/11/09 Python
学院书画协会部门职责
2013/11/28 职场文书
文明教师事迹材料
2014/01/16 职场文书
酒店开业策划方案
2014/06/02 职场文书
教师节感恩老师演讲稿
2014/08/28 职场文书
超市店庆活动方案
2014/08/31 职场文书
2014年远程教育工作总结
2014/12/09 职场文书
初中英语教师个人工作总结
2015/02/09 职场文书
教师节班会开场白
2015/06/01 职场文书
走近毛泽东观后感
2015/06/04 职场文书
寒假致家长的一封信
2015/10/10 职场文书