防止表單重復提交的方法

jopen 10年前發布 | 23K 次閱讀 表單 前端技術

防止表單被用戶重復提交,以下方法供參考:

1、禁掉提交按鈕。表單提交后,通過Javascript將提交按鈕設置為disable。.這種方法能夠防止用戶重復提交。但是,如果客戶端把Javascript禁止,這種方法就無效了。

2、Post/Redirect/Get模式,在提交后執行頁面重定向,這就是所謂的Post-Redirect-Get (PRG)模式。當用戶提交了表單后,執行一個客戶端的重定向,轉到提交成功信息頁面。 這能避免用戶按F5導致的重復提交,而其也不會出現瀏覽器表單重復提交的警告,也能消除按瀏覽器前進和后退按導致的同樣問題。

3、在數據庫里添加約束。在數據庫里添加唯一約束或創建唯一索引,防止出現重復數據。這是最有效的防止重復提交數據的方法。

4、在session中存放一個特殊標志。當表單頁面被請求時,生成一個特殊的字符標志串,存在session中,同時放在表單的隱藏域里。接受處理表單數據時,檢查標識字串是否存在,并立即從session中刪除它,然后正常處理數據。 如果發現表單提交里沒有有效的標志串,這說明表單已經被提交過了,忽略這次提交。 這使你的web應用有了更高級的XSRF保護。

以上方法中,更推薦2、3。

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!