重復提交是我們開發中會常碰到的一個問題,除了我們使用js來防止表單的重復提交,同時還可以使用php來防止重復提交.
例1,代碼如下:
- <?php
- /*
- * php中如何防止表單的重復提交
- */
- session_start();
- if (emptyempty($_SESSION['ip'])) {//第一次寫入操作,判斷是否記錄了IP地址,以此知道是否要寫入數據庫
- //開源代碼Vevb.com
- $_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.如果是重復提交表單,代碼如下:
- .if ($_SESSION["token"] != $token) {
- . // 不讓重復提交,在此處理
- . // header("location:".$_SERVER['PHP_SELF']);
- .} else {
- . // 正常的表單提交,在此處理
- . // echo "已提交";
- .}
4.設置token值,代碼如下:
$token = mt_rand(0,1000000); .$_SESSION['token'] = $token;
新聞熱點
疑難解答