<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    牛仔褲的夏天

    JAVA是藍色的- online

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      30 隨筆 :: 5 文章 :: 15 評論 :: 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();">  

      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 2006-01-04 15:35 luckyrobbie 閱讀(285) 評論(0)  編輯  收藏

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


    網站導航:
    博客園   IT新聞   Chat2DB   C++博客   博問  
     
    主站蜘蛛池模板: 国产伦一区二区三区免费 | 久香草视频在线观看免费| 久久久久久久久免费看无码| 亚洲一区二区三区夜色| 99re热精品视频国产免费| 久久久久亚洲精品无码蜜桃 | 亚洲精品无AMM毛片| 日韩精品无码区免费专区| 国产 亚洲 中文在线 字幕| 永久免费av无码网站大全| 直接进入免费看黄的网站| 亚洲成a人片在线观看久| 久久国产乱子伦精品免费午夜| 亚洲中文字幕无码日韩| 免费91最新地址永久入口| 亚洲成在人天堂在线| 国产在线观看片a免费观看| 亚洲一区二区观看播放| 高清在线亚洲精品国产二区| caoporm超免费公开视频| 亚洲AV无码久久寂寞少妇| 在线看片无码永久免费视频| 亚洲欧美日韩一区二区三区在线| 国产乱子伦片免费观看中字| 久久免费视频一区| 久久久久亚洲Av无码专| 日韩精品无码人妻免费视频| 一级做性色a爰片久久毛片免费| 国产亚洲婷婷香蕉久久精品| 成人免费视频网站www| 欧洲亚洲综合一区二区三区| 亚洲色偷偷偷鲁综合| 国产h视频在线观看网站免费| 鲁死你资源站亚洲av| 亚洲国产第一站精品蜜芽| 亚洲三级高清免费| 色哟哟国产精品免费观看| 亚洲综合激情另类小说区| 四虎永久在线精品免费观看地址| 两个人看的www视频免费完整版| 亚洲日本国产乱码va在线观看|