隨筆 - 100  文章 - 50  trackbacks - 0
          <2025年7月>
          293012345
          6789101112
          13141516171819
          20212223242526
          272829303112
          3456789

          常用鏈接

          留言簿(3)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          收藏夾

          我收藏的一些文章!

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          前兩種是利用javascript,后面一種是在使用Struts的情況下的參考實現


          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);       
                  }   
                  } 
          轉自網友
          posted on 2008-07-07 14:13 fly 閱讀(341) 評論(0)  編輯  收藏 所屬分類: jsp學習
          主站蜘蛛池模板: 北流市| 达尔| 汕头市| 确山县| 桂东县| 南城县| 大化| 台东县| 长泰县| 洪江市| 呼伦贝尔市| 含山县| 衡东县| 尖扎县| 文安县| 本溪市| 常山县| 长丰县| 上栗县| 开平市| 永泰县| 万全县| 卢龙县| 桃园市| 甘谷县| 威海市| 寿阳县| 达孜县| 永安市| 博湖县| 南乐县| 杂多县| 德化县| 纳雍县| 石景山区| 淮滨县| 威信县| 新竹县| 肃北| 承德县| 西青区|