分析ThinkPHP防止重復(fù)提交表單的方法實(shí)例
閱讀 48278 · 發(fā)布日期 2020-08-24 11:44 · 溫州優(yōu)光網(wǎng)絡(luò)科技有限公司|建站|APP小程序制作|做網(wǎng)站SEO推廣優(yōu)化
【摘要】
本文實(shí)例總結(jié)分析了ThinkPHP防止重復(fù)提交表單的方法。分享給大家供大家參考,具體如下:為什么會(huì)有表單重復(fù)的坑在開發(fā)中,如果一個(gè)新增或修改的表單,在后臺(tái)完成數(shù)據(jù)庫操作后我們?cè)O(shè)定的不是跳轉(zhuǎn)到其他頁面,還是返回本頁面,這時(shí)點(diǎn)擊瀏覽器的后退再提交或刷新頁面,會(huì)導(dǎo)致form表單重復(fù)提交,即這條記錄會(huì)被增加或修改兩次。導(dǎo)致表單... 【溫州小程序開發(fā),溫州微信公眾號(hào),平陽做網(wǎng)站,平陽網(wǎng)站建設(shè)公司,平陽小程序商城制作,昆陽萬全做網(wǎng)站,鰲江水頭小程序,蕭江騰蛟微信公眾號(hào),山門順溪南雁海西南麂鳳臥麻步懷溪網(wǎng)絡(luò)網(wǎng)店服務(wù),政采云網(wǎng)店管理服務(wù)】...
本文實(shí)例總結(jié)分析了ThinkPHP防止重復(fù)提交表單的方法。
分享給大家供大家參考,具體如下:
為什么會(huì)有表單重復(fù)的坑在開發(fā)中,如果一個(gè)新增或修改的表單,在后臺(tái)完成數(shù)據(jù)庫操作后我們?cè)O(shè)定的不是跳轉(zhuǎn)到其他頁面,還是返回本頁面,這時(shí)點(diǎn)擊瀏覽器的后退再提交或刷新頁面,會(huì)導(dǎo)致form表單重復(fù)提交,即這條記錄會(huì)被增加或修改兩次。
導(dǎo)致表單重復(fù)提交的原因是:
第一次提交的表單會(huì)被緩存到內(nèi)存中,直到頁面下次提交或頁面關(guān)閉或轉(zhuǎn)向其他頁面時(shí)才消失。
在自調(diào)用返回時(shí),內(nèi)存中的數(shù)據(jù)依然在,這時(shí)頁面中的判斷提交的代碼依然可以檢測(cè)到提交的值,顧會(huì)產(chǎn)生重復(fù)提交的效果。
相關(guān)學(xué)習(xí)推薦:
php編程(視頻)如何解決?總結(jié)網(wǎng)上的解決辦法和自己的測(cè)試,可以用以下幾個(gè)辦法:
方法1:
最簡(jiǎn)單:
頁面提交后轉(zhuǎn)到另一個(gè)頁面而不是本頁面,舉個(gè)栗子,比如你的頁面地址為https://www.php.cn/則該頁面的表單action地址可以為另外的處理地址,如 JS:$().ready(function(){
$("#login_btn").on('
click'
,function(){
$(this).attr('
disabled'
,true);
}
);
}
);
方法1+方法2 結(jié)合后,基本上90%以上的重復(fù)提交問題都能解決,但是大劉這里還是要說下第三種方法,即在服務(wù)端一勞永逸的解決這個(gè)問題方法3:
使用隱藏隨機(jī)TOKEN值的方法進(jìn)行重復(fù)提交判斷首先,在項(xiàng)目的functions.php中添加如下方法//創(chuàng)建TOKEN function createToken() {
$code = chr(mt_rand(0xB0, 0xF7)) . chr(mt_rand(0xA1, 0xFE)) . chr(mt_rand(0xB0, 0xF7)) . chr(mt_rand(0xA1, 0xFE)) . chr(mt_rand(0xB0, 0xF7)) . chr(mt_rand(0xA1, 0xFE));
session('
TOKEN'
, authcode($code));
}
//判斷TOKEN function checkToken($token) {
if ($token == session('
TOKEN'
)) {
session('
TOKEN'
, NULL);
return TRUE;
}
else {
return FALSE;
}
}
/* 加密TOKEN */ function authcode($str) {
$key = "YOURKEY";
$str = substr(md5($str), 8, 10);
return md5($key . $str);
}
在表單頁面form中填入以下HTML代碼HTML:在頁面展示前調(diào)用creatToken()方法生成token,在相應(yīng)控制器POST請(qǐng)求中 使用 checkToken() 進(jìn)行判斷是否重復(fù)提交if(IS_POST) {
$post_token = I('
post.TOKEN'
);
if(!checkToken($post_token)){
$this->error('
請(qǐng)不要重復(fù)提交頁面'
,U('
User/Index/login'
));
}
}
基本上,這3個(gè)方法配合著使用,就能解決ThinkPHP開發(fā)中表單重復(fù)提交問題,當(dāng)然,有同學(xué)說可以使用ThinkPHP的令牌環(huán)機(jī)制,這樣其實(shí)就更簡(jiǎn)單了,TP會(huì)默認(rèn)在表單中生成一個(gè)隱藏域,到時(shí)候判斷這個(gè)隱藏域是否存在以及和session中的值是否想的即可,原理和方法3是一樣的。
PS:今天終于把內(nèi)容用簡(jiǎn)書的markdown編輯器發(fā)出來了,果然markdown語法不是蓋的,整個(gè)排版都清爽了,不錯(cuò)不錯(cuò)。
相關(guān)學(xué)習(xí)推薦:
編程視頻以上就是分析ThinkPHP防止重復(fù)提交表單的方法實(shí)例的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!
微信
分享相關(guān)標(biāo)簽:
ThinkPHP 重復(fù)提交 表單本文轉(zhuǎn)載于:
jb51,如有侵犯,請(qǐng)聯(lián)系[email protected]刪除
上一篇:
實(shí)現(xiàn)PHP微信紅包API接口
下一篇:
實(shí)例講解php提交表單關(guān)閉layer彈窗iframe相關(guān)文章相關(guān)視頻php表單提交的數(shù)據(jù)丟失怎么辦案例分析PHP Web表單生成器php表單提交時(shí)獲取不到post數(shù)據(jù)怎么辦php禁止用戶重復(fù)提交表單分析ThinkPHP防止重復(fù)提交表單的方法實(shí)例ThinkPHP6.0 視圖ThinkPHP6.0 數(shù)據(jù)庫ThinkPHP6.0 請(qǐng)求 [溫州做網(wǎng)站PHP教程]