本文介紹下,在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不存在而報錯。