在開發中,如果一個新增或修改的表單,在後台完成資料庫操作後我們設定的不是跳到其他頁面,還是回到本頁面,這時點擊瀏覽器的後退再提交或刷新頁面,會導致form表單重複提交,即這條記錄會被增加或修改兩次。表單會被
快取到記憶體中,直到頁面下次提交或頁面關閉或轉向其他頁面時才消失。的程式碼依然可以偵測到提交的值,顧會產生重複提交的效果。
方法1http://yourdomain.com/User/Index/login
則該頁面的表單
action地址可以為另外的處理地址,如<form action="{:U('User/Index/check_login')}" method="post">
這樣報錯返回,或者用戶點擊回退
,還是會回到上一個地址,不過這種情況也不保險。這種方式一般是結合方法1來做的,透過JS來動態監聽使用者的點擊動作,動態將按鈕
屬性<form action="{:U('User/Index/check_login')}" method="post">
JS:$().ready(function(){
$("#login_btn").on('click',function(){
$(this).attr('disabled',true);
});
});
方法1+方法2 結合後,基本上90%以上的重複提交問題都能解決,但是大劉這裡還是要說下第三種方法,即在服務端一勞永逸的解決這個問題
方法3:使用隱藏隨機TOKEN值的方法進行重複提交判斷首先,在專案的functions.php中加入以下方法
//创建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:
<input type="hidden" name="TOKEN" value="{:session('TOKEN')}" />
在頁面展示前呼叫creatToken ()方法產生token,在對應
控制器POST請求中使用checkToken() 進行判斷是否重複提交
if(IS_POST) { $post_token = I('post.TOKEN'); if(!checkToken($post_token)){ $this->error('请不要重复提交页面',U('User/Index/login')); } }
基本上,這3個方法配合著使用,就能解決ThinkPHP開發中表單重複提交問題,當然,有同學說可以使用ThinkPHP的令牌環機制,這樣其實就更簡單了,TP會預設在表單中產生一個隱藏域,到時候判斷這個隱藏域是否存在以及和session中的值是否想的即可,原理和方法3是一樣的。
以上是ThinkPHP技巧如何防止重複提交表單的詳細內容。更多資訊請關注PHP中文網其他相關文章!