解決php表單重復(fù)提交實現(xiàn)方法
重復(fù)提交是我們開發(fā)中會常碰到的一個問題,除了我們使用js來防止表單的重復(fù)提交,同時還可以使用php來防止重復(fù)提交哦。
<?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. 如果有表單提交
if (isset($token))
token以hidden的形式包含在form當(dāng)中。
<input type="hidden" name="token" value="<?php echo $token; ?>" />
3. 如果是重復(fù)提交表單
if ($_SESSION["token"] != $token) {
// 不讓重復(fù)提交,在此處理
// header("location:".$_SERVER['PHP_SELF']);
} else {
// 正常的表單提交,在此處理
// echo "已提交";
}
4. 設(shè)置token值
$token = mt_rand(0,1000000);
2$_SESSION['token'] = $token;
以上就是關(guān)于如何解決php表單重復(fù)提交實現(xiàn)方法,希望對大家的學(xué)習(xí)有所幫助。
- PHP防止表單重復(fù)提交的幾種常用方法匯總
- ThinkPHP 防止表單重復(fù)提交的方法
- php解決和避免form表單重復(fù)提交的幾種方法
- php通過記錄IP來防止表單重復(fù)提交方法分析
- PHP使用token防止表單重復(fù)提交的方法
- php 防止表單重復(fù)提交兩種實現(xiàn)方法
- PHP+Session防止表單重復(fù)提交的解決方法
- 詳解php curl帶有csrf-token驗證模擬提交方法
- Thinkphp5 微信公眾號token驗證不成功的原因及解決方法
- php版微信開發(fā)Token驗證失敗或請求URL超時問題的解決方法
- PHP實現(xiàn)防止表單重復(fù)提交功能【基于token驗證】
相關(guān)文章
兩級聯(lián)動select刷新后其值保持不變的實現(xiàn)方法
兩級聯(lián)動select刷新后,select值保持不變即點擊提交按鈕后,頁面select中繼續(xù)維持提交前的值,下面有個不錯的示例,大家可以參考下2014-01-01
用sql命令修改數(shù)據(jù)表中的一個字段為非空(not null)的語句
今天群里的一個朋友問如何用sql命令修改數(shù)據(jù)表中的一個字段為非空(not null),經(jīng)常測試下面的代碼即可。2010-06-06
php使用自定義函數(shù)實現(xiàn)漢字分割替換功能示例
這篇文章主要介紹了php使用自定義函數(shù)實現(xiàn)漢字分割替換功能,結(jié)合實例形式分析了php針對漢字的遍歷、轉(zhuǎn)換與分割操作相關(guān)技巧,需要的朋友可以參考下2017-01-01
PHP連接SQLServer2005的實現(xiàn)方法(附ntwdblib.dll下載)
為了php連接sql2005 ,我在網(wǎng)絡(luò)上找了一大堆資料在我的csdn博客中.晚上3:05分時候終于搞定了2012-07-07
與文件上傳有關(guān)的php配置參數(shù)總結(jié)
搞個了圖片上傳,死活不好使,后來發(fā)現(xiàn)是php參數(shù)配置的問題,下面總結(jié)下與文件上傳有關(guān)的php參數(shù),有類似情況的朋友可以參考下哈2013-06-06

