好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > JSP避免Form重復提交的三種方案

JSP避免Form重復提交的三種方案

熱門標簽:外呼直播語音系統 地圖標注專業和非專業 甘肅銷售電銷機器人公司 福建電銷貓機器人收費 汝南縣地圖標注app 智能電話機器人銷售話術 湖北地圖標注公司 山東ai外呼電銷機器人好用嗎 四川正規外呼系統軟件
1 javascript ,設置一個變量,只允許提交一次。
  script language="javascript">
   var checksubmitflg = false;
   function checksubmit() {
   if (checksubmitflg == true) {
   return false;
   }
   checksubmitflg = true;
   return true;
   }
   document.ondblclick = function docondblclick() {
   window.event.returnvalue = false;
   }
   document.onclick = function doconclick() {
   if (checksubmitflg) {
   window.event.returnvalue = false;
   }
   }
  /script>
  html:form action="myaction.do" method="post" onsubmit="return checksubmit();">  
  2 還是javascript,將提交按鈕或者image置為disable  
   html:form action="myaction.do" method="post"
   onsubmit="getelbyid('submitinput').disabled = true; return true;">   
   html:image styleid="submitinput" src="images/ok_b.gif" border="0" /> 
   /html:form>  
  3 利用struts的同步令牌機制  
  利用同步令牌(token)機制來解決web應用中重復提交的問題,struts也給出了一個參考實現。
  基本原理: 
  服務器端在處理到達的請求之前,會將請求中包含的令牌值與保存在當前用戶會話中的令牌值進行比較,看是否匹配。在處理完該請求后,且在答復發送給客戶端之前,將會產生一個新的令牌,該令牌除傳給客戶端以外,也會將用戶會話中保存的舊的令牌進行替換。這樣如果用戶回退到剛才的提交頁面并再次提交的話,客戶端傳過來的令牌就和服務器端的令牌不一致,從而有效地防止了重復提交的發生。 
  if (istokenvalid(request, true)) {
   // your code here
   return mapping.findforward("success");
  } else {
   savetoken(request);
   return mapping.findforward("submitagain");
  } 
  struts根據用戶會話id和當前系統時間來生成一個唯一(對于每個會話)令牌的,具體實現可以參考tokenprocessor類中的generatetoken()方法。  
  1. //驗證事務控制令牌,html:form >會自動根據session中標識生成一個隱含input代表令牌,防止兩次提交
  2. 在action中:  
   //input type="hidden" name="org.apache.struts.taglib.html.token"
   // value="6aa35341f25184fd996c4c918255c3ae">
   if (!istokenvalid(request))
   errors.add(actionerrors.global_error,
   new actionerror("error.transaction.token"));
   resettoken(request); //刪除session中的令牌  
  3. action有這樣的一個方法生成令牌  
   protected string generatetoken(httpservletrequest request) {  
   httpsession session = request.getsession();
   try {
   byte id[] = session.getid().getbytes();
   byte now[] = new long(system.currenttimemillis()).tostring().getbytes();
   messagedigest md = messagedigest.getinstance("md5");
   md.update(id);
   md.update(now);
   return (tohex(md.digest()));
   } catch (illegalstateexception e) {
   return (null);
   } catch (nosuchalgorithmexception e) {
   return (null);
   }
   }
您可能感興趣的文章:
  • JSP使用自定義標簽防止表單重復提交的方法
  • JSP刷新頁面表單重復提交問題解決辦法分享
  • jsp 重復提交問題
  • jquery ajax 如何向jsp提交表單數據
  • jquery ajax提交表單從action傳值到jsp實現小結
  • JSP針對表單重復提交的處理方法

標簽:南充 臨沂 昌都 梅州 吳忠 肇慶 白銀 黔東

巨人網絡通訊聲明:本文標題《JSP避免Form重復提交的三種方案》,本文關鍵詞  JSP,避免,Form,重復,提交,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《JSP避免Form重復提交的三種方案》相關的同類信息!
  • 本頁收集關于JSP避免Form重復提交的三種方案的相關信息資訊供網民參考!
  • 推薦文章