常見表單重復(fù)提交問題整理及解決方法
更新時(shí)間:2013年11月13日 16:22:30 作者:
常見的重復(fù)提交問題如點(diǎn)擊提交按鈕兩次、點(diǎn)擊刷新按鈕等等,下面為大家整理了防止表單重復(fù)提交的方法,感興趣的朋友可以參考下
/**
*
* @authors Benjamin
* @date 2013-11-13 10:16:59
*/
一、常見的重復(fù)提交問題
a>點(diǎn)擊提交按鈕兩次。
b>點(diǎn)擊刷新按鈕。
c>使用瀏覽器后退按鈕重復(fù)之前的操作,導(dǎo)致重復(fù)提交表單。
d>使用瀏覽器歷史記錄重復(fù)提交表單。
e>瀏覽器重復(fù)的HTTP請(qǐng)求。
二、防止表單重復(fù)提交的方法
a>禁掉提交按鈕。表單提交后disabled現(xiàn)在的按鈕或者取消該按鈕的點(diǎn)擊事件或者默認(rèn)事件。這種方法防止心急的用戶多次點(diǎn)擊按鈕。但有個(gè)問題,如果在客戶端把Javascript給禁止掉,這種方法就無效了,當(dāng)然現(xiàn)代的web站點(diǎn)來說,應(yīng)該很少了。
b>Post/Redirect/Get模式。在提交后執(zhí)行頁面重定向,這就是所謂的Post-Redirect-Get (PRG)模式。簡(jiǎn)言之,當(dāng)用戶提交了表單后,你去執(zhí)行一個(gè)客戶端的重定向,轉(zhuǎn)到提交成功信息頁面。這能避免用戶按F5導(dǎo)致的重復(fù)提交,而其也不會(huì)出現(xiàn)瀏覽器表單重復(fù)提交的警告,也能消除按瀏覽器前進(jìn)和后退按導(dǎo)致的同樣問題。
c>使用cookie處理表單重復(fù)提交
PHP中的實(shí)現(xiàn):
lt;?php
if(isset($_POST['go'])){
setcookie("tempcookie","",time()+30);
header("Location:".$_SERVER[PHP_SELF]);exit();
} if(isset($_COOKIE["tempcookie"])){
setcookie("tempcookie","",0);echo "您已經(jīng)提交過表單";
}
?>
d>在session中存放一個(gè)特殊標(biāo)志。當(dāng)表單頁面被請(qǐng)求時(shí),生成一個(gè)特殊的字符標(biāo)志串,存在session中,同時(shí)放在表單的隱藏域里。接受處理表單數(shù)據(jù)時(shí),檢查標(biāo)識(shí)字串是否存在,并立即從session中刪除它,然后正常處理數(shù)據(jù)。如果發(fā)現(xiàn)表單提交里沒有有效的標(biāo)志串,這說明表單已經(jīng)被提交過了,忽略這次提交。這使你的web應(yīng)用有了更高級(jí)的XSRF保護(hù)。
e>在數(shù)據(jù)庫里添加約束。在數(shù)據(jù)庫里添加唯一約束或創(chuàng)建唯一索引,防止出現(xiàn)重復(fù)數(shù)據(jù)。這是最有效的防止重復(fù)提交數(shù)據(jù)的方法。
*
* @authors Benjamin
* @date 2013-11-13 10:16:59
*/
一、常見的重復(fù)提交問題
a>點(diǎn)擊提交按鈕兩次。
b>點(diǎn)擊刷新按鈕。
c>使用瀏覽器后退按鈕重復(fù)之前的操作,導(dǎo)致重復(fù)提交表單。
d>使用瀏覽器歷史記錄重復(fù)提交表單。
e>瀏覽器重復(fù)的HTTP請(qǐng)求。
二、防止表單重復(fù)提交的方法
a>禁掉提交按鈕。表單提交后disabled現(xiàn)在的按鈕或者取消該按鈕的點(diǎn)擊事件或者默認(rèn)事件。這種方法防止心急的用戶多次點(diǎn)擊按鈕。但有個(gè)問題,如果在客戶端把Javascript給禁止掉,這種方法就無效了,當(dāng)然現(xiàn)代的web站點(diǎn)來說,應(yīng)該很少了。
b>Post/Redirect/Get模式。在提交后執(zhí)行頁面重定向,這就是所謂的Post-Redirect-Get (PRG)模式。簡(jiǎn)言之,當(dāng)用戶提交了表單后,你去執(zhí)行一個(gè)客戶端的重定向,轉(zhuǎn)到提交成功信息頁面。這能避免用戶按F5導(dǎo)致的重復(fù)提交,而其也不會(huì)出現(xiàn)瀏覽器表單重復(fù)提交的警告,也能消除按瀏覽器前進(jìn)和后退按導(dǎo)致的同樣問題。
c>使用cookie處理表單重復(fù)提交
PHP中的實(shí)現(xiàn):
復(fù)制代碼 代碼如下:
lt;?php
if(isset($_POST['go'])){
setcookie("tempcookie","",time()+30);
header("Location:".$_SERVER[PHP_SELF]);exit();
} if(isset($_COOKIE["tempcookie"])){
setcookie("tempcookie","",0);echo "您已經(jīng)提交過表單";
}
?>
d>在session中存放一個(gè)特殊標(biāo)志。當(dāng)表單頁面被請(qǐng)求時(shí),生成一個(gè)特殊的字符標(biāo)志串,存在session中,同時(shí)放在表單的隱藏域里。接受處理表單數(shù)據(jù)時(shí),檢查標(biāo)識(shí)字串是否存在,并立即從session中刪除它,然后正常處理數(shù)據(jù)。如果發(fā)現(xiàn)表單提交里沒有有效的標(biāo)志串,這說明表單已經(jīng)被提交過了,忽略這次提交。這使你的web應(yīng)用有了更高級(jí)的XSRF保護(hù)。
e>在數(shù)據(jù)庫里添加約束。在數(shù)據(jù)庫里添加唯一約束或創(chuàng)建唯一索引,防止出現(xiàn)重復(fù)數(shù)據(jù)。這是最有效的防止重復(fù)提交數(shù)據(jù)的方法。
相關(guān)文章
(推薦一個(gè)超好的JS函數(shù)庫)S.Sams Lifexperience ScriptClassLib
(推薦一個(gè)超好的JS函數(shù)庫)S.Sams Lifexperience ScriptClassLib...2007-04-04Layui實(shí)現(xiàn)主窗口和Iframe層參數(shù)傳遞
今天小編就為大家分享一篇Layui實(shí)現(xiàn)主窗口和Iframe層參數(shù)傳遞,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-11-11一文吃透JS樹狀結(jié)構(gòu)的數(shù)據(jù)處理(增刪改查)
在開發(fā)后臺(tái)管理系統(tǒng)時(shí),常常會(huì)涉及到各種樹狀結(jié)構(gòu)的數(shù)據(jù)處理邏輯,例如:增,刪,改,查等。而樹狀結(jié)構(gòu)的處理就沒有數(shù)組那么的直觀。本文為大家總結(jié)了JS樹狀結(jié)構(gòu)的數(shù)據(jù)處理的方法,需要的可以參考下2022-07-07關(guān)于js拖拽上傳 [一個(gè)拖拽上傳修改頭像的流程]
拖拽是操作系統(tǒng)用戶體驗(yàn)最偉大的改進(jìn)之一。它讓人隨心所欲的操作,更符合人們的直觀感受。2011-07-07Javascript模擬加速運(yùn)動(dòng)與減速運(yùn)動(dòng)代碼分享
這篇文章主要介紹了Javascript加速運(yùn)動(dòng)與減速運(yùn)動(dòng)代碼分享,需要的朋友可以參考下2014-12-12