標籤:c style class a http tar
重複提交是我們開發中會常碰到的一個問題,除了我們使用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; |
大家在累了的時候,就去看看邪惡GIF動態圖吧,內涵而不色情,愉悅身心!www.530312.net