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

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

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

    隨筆 - 251  文章 - 504  trackbacks - 0
    <2006年7月>
    2526272829301
    2345678
    9101112131415
    16171819202122
    23242526272829
    303112345

    本博客系個(gè)人收集材料及學(xué)習(xí)記錄之用,各類“大俠”勿擾!

    留言簿(14)

    隨筆分類

    收藏夾

    My Favorite Web Sites

    名Bloger

    非著名Bloger

    搜索

    •  

    積分與排名

    • 積分 - 202520
    • 排名 - 285

    最新評(píng)論

    1 javascript ,設(shè)置一個(gè)變量,只允許提交一次。 

      <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的同步令牌機(jī)制  

      利用同步令牌(Token)機(jī)制來解決Web應(yīng)用中重復(fù)提交的問題,Struts也給出了一個(gè)參考實(shí)現(xiàn)。

      基本原理: 

      服務(wù)器端在處理到達(dá)的請(qǐng)求之前,會(huì)將請(qǐng)求中包含的令牌值與保存在當(dāng)前用戶會(huì)話中的令牌值進(jìn)行比較,看是否匹配。在處理完該請(qǐng)求后,且在答復(fù)發(fā)送給客戶端之前,將會(huì)產(chǎn)生一個(gè)新的令牌,該令牌除傳給客戶端以外,也會(huì)將用戶會(huì)話中保存的舊的令牌進(jìn)行替換。這樣如果用戶回退到剛才的提交頁(yè)面并再次提交的話,客戶端傳過來的令牌就和服務(wù)器端的令牌不一致,從而有效地防止了重復(fù)提交的發(fā)生。 

      if (isTokenValid(request, true)) {

       // your code here

       return mapping.findForward("success");

      } else {

       saveToken(request);

       return mapping.findForward("submitagain");

      } 

      Struts根據(jù)用戶會(huì)話ID和當(dāng)前系統(tǒng)時(shí)間來生成一個(gè)唯一(對(duì)于每個(gè)會(huì)話)令牌的,具體實(shí)現(xiàn)可以參考TokenProcessor類中的generateToken()方法。  

      1. //驗(yàn)證事務(wù)控制令牌,<html:form >會(huì)自動(dòng)根據(jù)session中標(biāo)識(shí)生成一個(gè)隱含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有這樣的一個(gè)方法生成令牌  

       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-07-22 11:34 matthew 閱讀(200) 評(píng)論(0)  編輯  收藏 所屬分類: JavaEE
    主站蜘蛛池模板: 特级毛片爽www免费版| 亚洲娇小性xxxx色| 久久高潮一级毛片免费| 亚洲国产精品无码久久九九| 国产不卡免费视频| 午夜亚洲国产理论片二级港台二级| 国产精品午夜免费观看网站| www视频在线观看免费| 亚洲精品中文字幕无码AV| 57pao国产成永久免费视频| 亚洲国产精品白丝在线观看| 无限动漫网在线观看免费| 亚洲熟女www一区二区三区| 久9热免费精品视频在线观看| 啦啦啦手机完整免费高清观看| 亚洲AV无码久久精品成人| 国产精品亚洲lv粉色| 四虎影视在线永久免费观看| www免费插插视频| 日本特黄特色aa大片免费| 老司机午夜性生免费福利| 成年轻人网站色免费看| 老子影院午夜伦不卡亚洲| 国产偷国产偷亚洲高清日韩| 国产精品区免费视频| 久久久亚洲精品蜜桃臀| 一级毛片在线免费看| 亚洲午夜一区二区三区| 亚洲精品A在线观看| 色欲国产麻豆一精品一AV一免费 | 日本亚洲视频在线| 91香蕉国产线观看免费全集| 亚洲 欧洲 自拍 另类 校园| 2021精品国产品免费观看| 久久精品国产69国产精品亚洲| 香港一级毛片免费看| 亚洲va无码专区国产乱码| 大陆一级毛片免费视频观看| 中文字幕免费观看视频| 亚洲噜噜噜噜噜影院在线播放| 亚洲电影在线免费观看|