我的Blog我做主^_^

          走向一條通往JAVA的不歸路...

            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
            64 隨筆 :: 68 文章 :: 77 評論 :: 0 Trackbacks
           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();">  
           -------------------------------------------------------------------------------------------------------------------------------------

          <script language="JavaScript">
             <!--
             
             var checkSubmitFlag=true;
             function checkSubmit()
             {
              if(true==checkSubmitFlag)
              {
               //document.theForm.btnSubmit.disabled = true;
               document.theForm.submit();
               checkSubmitFlag = false;
               
              }
              else
              {
               alert("你已經提交了表單,請勿重復提交。"); 
              }
             }
             
             
             -->
             
            </script>

          其中注釋的這句//document.theForm.btnSubmit.disabled = true;
          意思是讓提交后的按鈕,禁用掉。
          而,else則是彈出了一個警告框,相對來說,彈出警告框,不是那么友好。

            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);

             }

             }

          http://www.ycgczj.com.cn/45034.html


           



          posted on 2007-02-12 08:57 java_蟈蟈 閱讀(214) 評論(1)  編輯  收藏

          評論

          # re: JSP避免Form重復提交的三種方案[未登錄] 2008-12-13 21:22 1
          1  回復  更多評論
            


          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 保亭| 灵川县| 莱芜市| 惠来县| 灌阳县| 昌平区| 大庆市| 濉溪县| 宜君县| 潼关县| 临潭县| 延寿县| 富川| 澄迈县| 永福县| 厦门市| 容城县| 西吉县| 颍上县| 金华市| 台安县| 南江县| 庆元县| 托克托县| 阿图什市| 东莞市| 青河县| 巩义市| 金堂县| 读书| 滕州市| 布拖县| 宕昌县| 绥中县| 新乡县| 卫辉市| 颍上县| 闻喜县| 南靖县| 阿拉善左旗| 阿拉善盟|