隨筆 - 100  文章 - 50  trackbacks - 0
          <2025年5月>
          27282930123
          45678910
          11121314151617
          18192021222324
          25262728293031
          1234567

          常用鏈接

          留言簿(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 閱讀(335) 評論(0)  編輯  收藏 所屬分類: jsp學習
          主站蜘蛛池模板: 靖边县| 苍南县| 孝义市| 安阳县| 金溪县| 泸水县| 阳城县| 苏尼特左旗| 卢龙县| 贞丰县| 揭西县| 鄂伦春自治旗| 宁阳县| 溧水县| 融水| 昆明市| 张家港市| 邮箱| 木兰县| 富宁县| 昌黎县| 孟津县| 韶关市| 阿克陶县| 驻马店市| 定结县| 广平县| 克拉玛依市| 吉安市| 应城市| 梁河县| 湘潭县| 阳谷县| 泰兴市| 文登市| 游戏| 娱乐| 古浪县| 德庆县| 开原市| 日土县|