本文介绍下,在php编程中,防止页面重复提交的方法,包括提交按钮置disabled、过时时间法、token销毁法等,有须要的朋友参考下。
本文原始连接:http://www.codepearl.com
本节内容:
php防止页面重复提交 php
说是php中防止页面的重复提交,其实还说到了js代码防止重复提交的方法。 编程
一、提交按钮置disabled
当用户提交后,当即把按钮置为不可用状态。这种用js来实现。
提交前:
session
代码示例:
$("#submit").attr('disabled','true');
$("#submit").val("正在提交,请稍等");
执行后,把按钮置为原来状态:
app
代码示例:
$('#submit ').removeAttr('disabled');
$("#submit ").val("肯定提交");
二、过时时间法
思路:
当用户提交按钮后生成一个token(每次业务提交token 为惟一值)存入session,并设置过时时间。
当用户再此提交时,检测token是否一致且是否过时,若一致且没有过时,则认为提交了二次。
当程序执行出错时,则须要清除存入session的值。
例子:
函数
代码示例:
<?php //防止页面重复提交 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 { // www.codepearl.com $_SESSION['token'] = $token; $_SESSION['expire_time'] = $time; //session写入的时候会等待整个页面加载完成,用此函数能够当即写入 session_write_close(); return true; } } //删除存入的值 function cancelRepeatSubmit() { unset($_SESSION['token']); unset($_SESSION['expire_time']); }
三、token销毁法 思路: 当页面进行加装的时候生成token,存在session中,并写在表单里。 表单提交时,随表单提交给服务端,服务端经过session存入的token与token进行比较,若相等,则销毁seesion中存入的token,当页面遭到二次提交的时候,因为存入session中的token不存在而报错。