重復提交是我們開發中會常碰到的一個問題,除了我們使用js來防止表單的重復提交,同時還可以使用php來防止重復提交哦。
例1
代碼如下 復制代碼<?php
/*
* php中如何防止表單的重復提交
*/
session_start();
if (empty($_SESSION['ip'])) {//第一次寫入操作,判斷是否記錄了IP地址,以此知道是否要寫入數據庫
$_SESSION['ip'] = $_SERVER['REMOTE_ADDR']; //第一次寫入,為後面刷新或後退的判斷做個鋪墊
//...........//寫入數據庫操作
} else {//已經有第一次寫入後的操作,也就不再寫入數據庫
echo '請不要再次刷新和後退'; //寫一些已經寫入的提示或其它東西
}
?>
具體原理
session范圍變量token來防止。
1. 開啟session:
session_start();
2. 如果有表單提交
代碼如下 復制代碼if (isset($token))
token以hidden的形式包含在form當中。
<input type="hidden" name="token" value="<?php echo $token; ?>" />
3. 如果是重復提交表單
1.if ($_SESSION["token"] != $token) {
2. // 不讓重復提交,在此處理
3. // header("location:".$_SERVER['PHP_SELF']);
4.} else {
5. // 正常的表單提交,在此處理
6. // echo "已提交";
7.}
4. 設置token值
代碼如下 復制代碼1.$token = mt_rand(0,1000000);
2.$_SESSION['token'] = $token;