首頁 >web前端 >js教程 >常見表單重複提交問題整理及解決方法_javascript技巧

常見表單重複提交問題整理及解決方法_javascript技巧

WBOY
WBOY原創
2016-05-16 17:15:411097瀏覽

/**
*
* @authors Benjamin
* @date 2013-11-13 10:16:59
*/

一、常見的重複提交問題
a>點擊提交按鈕兩次。
b>點選刷新按鈕。
c>使用瀏覽器後退按鈕重複先前的操作,導致重複提交表單。
d>使用瀏覽器歷史記錄重複提交表單。
e>瀏覽器重複的HTTP請求。

二、防止表單重複提交的方法
  a>禁掉提交按鈕。表單提交後disabled現在的按鈕或取消該按鈕的點擊事件或預設事件。這種方法可防止心急的用戶多次點擊按鈕。但有個問題,如果在客戶端把Javascript給禁止掉,這種方法就無效了,當然現代的web站點來說,應該就很少了。

  b>Post/Redirect/Get模式。在提交後執行頁面重定向,這就是所謂的Post-Redirect-Get (PRG)模式。簡言之,當使用者提交了表單後,你去執行一個客戶端的重定向,轉到提交成功資訊頁面。這能避免使用者按F5導致的重複提交,而其也不會出現瀏覽器表單重複提交的警告,也能消除按瀏覽器前進和後退按導致的同樣問題。

  c>使用cookie處理表單重複提交
  PHP中的實作:

複製程式碼




  lt;?php
   if(isset($_POST['go'])){
   setcookie("tempcookie",""",time() 30); 🎜>   header("Location:".$_SERVER[PHP_SELF]);exit();
   } if(isset($_COOKIE["tempcookie"])){
  tempcookie," 0);echo "您已經提交過表單";
   }
   ?>

  d>在session中存放一個特殊標誌。當表單頁面被要求時,產生一個特殊的字元標誌串,存在session中,同時放在表單的隱藏域裡。接受處理表單資料時,檢查標識字符串是否存在,並立即從session中刪除它,然後正常處理資料。如果發現表單提交裡沒有有效的標誌串,這表示表單已經被提交過了,忽略這次提交。這讓你的web應用程式有了更進階的XSRF保護。   e>在資料庫中新增約束。在資料庫裡新增唯一約束或建立唯一索引,防止重複資料出現。這是最有效的防止重複提交資料的方法。
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn