《PHP實戰(zhàn):解決php表單重復(fù)提交實現(xiàn)方法》要點:
本文介紹了PHP實戰(zhàn):解決php表單重復(fù)提交實現(xiàn)方法,希望對您有用。如果有疑問,可以聯(lián)系我們。
重復(fù)提交是我們開發(fā)中會常碰到的一個問題,除了我們使用js來防止表單的重復(fù)提交,同時還可以使用php來防止重復(fù)提交哦.
PHP學(xué)習(xí)
<?php /* * php中如何防止表單的重復(fù)提交 */ session_start(); if (empty($_SESSION['ip'])) {//第一次寫入操作,判斷是否記錄了IP地址,以此知道是否要寫入數(shù)據(jù)庫 $_SESSION['ip'] = $_SERVER['REMOTE_ADDR']; //第一次寫入,為后面刷新或后退的判斷做個鋪墊 //...........//寫入數(shù)據(jù)庫操作 } else {//已經(jīng)有第一次寫入后的操作,也就不再寫入數(shù)據(jù)庫 echo '請不要再次刷新和后退'; //寫一些已經(jīng)寫入的提示或其它東西 } ?>
具體原理
session范圍變量token來防止.
1. 開啟session:
session_start();
2. 如果有表單提交
PHP學(xué)習(xí)
if (isset($token))
token以hidden的形式包含在form當(dāng)中.
PHP學(xué)習(xí)
<input type="hidden" name="token" value="<?php echo $token; ?>" />
?PHP學(xué)習(xí)
3. 如果是重復(fù)提交表單
PHP學(xué)習(xí)
if ($_SESSION["token"] != $token) { // 不讓重復(fù)提交,在此處理 // header("location:".$_SERVER['PHP_SELF']); } else { // 正常的表單提交,在此處理 // echo "已提交"; }
4. 設(shè)置token值
$token = mt_rand(0,1000000);
2$_SESSION['token'] = $token;PHP學(xué)習(xí)
以上就是關(guān)于如何解決php表單重復(fù)提交實現(xiàn)辦法,希望對大家的學(xué)習(xí)有所幫助.PHP學(xué)習(xí)
歡迎參與《PHP實戰(zhàn):解決php表單重復(fù)提交實現(xiàn)方法》討論,分享您的想法,維易PHP學(xué)院為您提供專業(yè)教程。
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.snjht.com/jiaocheng/8629.html