国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

常見表單重復提交問題整理及解決方法

2024-05-06 15:54:51
字體:
來源:轉載
供稿:網友
常見的重復提交問題如點擊提交按鈕兩次、點擊刷新按鈕等等,下面為大家整理了防止表單重復提交的方法,感興趣的朋友可以參考下

/**
*
* @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"])){
   setcookie("tempcookie","",0);echo "您已經提交過表單";
   }
   ?>


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

  e>在數據庫里添加約束。在數據庫里添加唯一約束或創建唯一索引,防止出現重復數據。這是最有效的防止重復提交數據的方法。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 石景山区| 吉木萨尔县| 绥阳县| 怀化市| 沧源| 忻城县| 大荔县| 贵港市| 崇信县| 木兰县| 宁远县| 威信县| 云龙县| 长兴县| 鄄城县| 新宁县| 浠水县| 渑池县| 当涂县| 兴隆县| 泸西县| 瑞昌市| 周至县| 九台市| 静海县| 鄱阳县| 郧西县| 九龙县| 治多县| 左权县| 阜城县| 阜阳市| 包头市| 大荔县| 肇庆市| 赤峰市| 苏尼特左旗| 巴中市| 桃园市| 如东县| 耒阳市|