php 解決表單重復(fù)提交實(shí)現(xiàn)方法介紹
重復(fù)提交是我們開發(fā)中會常碰到的一個(gè)問題,除了我們使用js來防止表單的重復(fù)提交,同時(shí)還可以使用php來防止重復(fù)提交哦。
例1
/*
* php中如何防止表單的重復(fù)提交
*/
session_start();
if (empty($_SESSION['ip'])) {//第一次寫入操作,判斷是否記錄了IP地址,以此知道是否要寫入數(shù)據(jù)庫
$_SESSION['ip'] = $_SERVER['REMOTE_ADDR']; //第一次寫入,為后面刷新或后退的判斷做個(gè)鋪墊
//...........//寫入數(shù)據(jù)庫操作
} else {//已經(jīng)有第一次寫入后的操作,也就不再寫入數(shù)據(jù)庫
echo '請不要再次刷新和后退'; //寫一些已經(jīng)寫入的提示或其它東西
}
?>
具體原理
session范圍變量token來防止。
1. 開啟session:
session_start();
2. 如果有表單提交
if (isset($token))
token以hidden的形式包含在form當(dāng)中。
3. 如果是重復(fù)提交表單
1.if ($_SESSION["token"] != $token) {
2. // 不讓重復(fù)提交,在此處理
3. // header("location:".$_SERVER['PHP_SELF']);
4.} else {
5. // 正常的表單提交,在此處理
6. // echo "已提交";
7.}
4. 設(shè)置token值
1.$token = mt_rand(0,1000000);
2.$_SESSION['token'] = $token;
php 解決表單重復(fù)提交實(shí)現(xiàn)方法介紹
------解決方案--------------------
是否允許用戶正常情況的第二次提交呢?
------解決方案--------------------
實(shí)際上沒有這么做的
更多信息請查看IT技術(shù)專欄