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

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

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

    yxhxj2006

    常用鏈接

    統計

    最新評論

    防止重復登錄請求

    過頁頭生成Token,進行請求驗證,解決Ajax請求安全問題。目前為止我做的最多的防止ajax請求攻擊的就是添加驗證碼、添加隨機Token,限制同一請求在規定時間內的最大請求數。

    下面重點說說添加隨機Token限制:
    token是為了防止表單重復提交,token 原理大致為:

    1:顯示表單的那個 action 中使用 createToken() 生成一個隨機的 token值,并存放在服務端(session或者cache中),并且傳遞一份到頁面中

    2:表單頁面使用一個隱藏表單域獲取后端傳過來的 token值,該表單頁面提交時會將此 token 值一同提交到后端

    3:在表單頁面提交到的 actioin 中使用 validateToken() 將服務端與表單隱藏域中的 token 值進行對比,如果服務端存在 token值并且與表單提交過來的值相等,證明是第一次提交。

    4:每次校驗過后服務端的 token 值會立即被清除,所以當用戶重復提交時,后面的提交校驗都再也無法通過。從而實現了防止重復提交的功能,validateToken 是在 synchronized 塊中執行的保障了多線程下的安全性。

        token 會優先存入 me.setTokenCache(ITokenCache) 指定的 TokenCache 中,如果未指定則默認使用 session 來存放

    但是這種機制是有問題的,比如我是用ajax提交表單,提交完成以后表單頁面并不刷新,然后我修改了部分數據以后再次提交頁面,那么token還是之前的那個token,后臺會以為這個為重復提交不能通過校驗,那么請求就不能完成,數據無法得到正確的處理。我認為合理的機制應該是這樣的:

    1:顯示表單的那個 action 中使用 createToken() 生成一個隨機的 token值,并且傳遞一份到頁面中

    2:表單頁面使用一個隱藏表單域獲取后端傳過來的 token值,該表單頁面提交時會將此 token 值一同提交到后端

    3:將提交過來的token值放入session或者cache中,然后執行controller中的代碼,代碼全部執行完以后,再把存入session或cache中的token值刪除掉;驗證用戶是否為重復提交只需要驗證提交過來的token是否存在于session或cache中,有則為重復提交,無則為正常提交。

    4:該邏輯應該可以寫成一個Interceptor,在需要的地方加上,或者直接設為全局攔截器都是可以的,簡單,快捷;

    posted on 2015-12-03 16:03 奮斗成就男人 閱讀(502) 評論(0)  編輯  收藏


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


    網站導航:
     
    主站蜘蛛池模板: 成人无遮挡裸免费视频在线观看| 中文字幕在线观看免费视频 | 亚洲日韩一区二区一无码| 91精品免费不卡在线观看| 亚洲人成网站在线播放影院在线| 在线视频网址免费播放| 国产V亚洲V天堂无码| 久久精品私人影院免费看| 亚洲日韩图片专区第1页| 免费无遮挡无码永久视频| 亚洲成a人片7777| 色妞WWW精品免费视频| 亚洲国产精品网站在线播放| 好吊妞在线成人免费| 午夜亚洲国产精品福利| 国产91精品一区二区麻豆亚洲 | 免费av一区二区三区| 亚洲av女电影网| 亚州免费一级毛片| 亚洲欧洲av综合色无码 | 久久久久久久亚洲精品| 久久免费线看线看| 91亚洲性爱在线视频| 美女被免费视频网站a国产| 深夜福利在线免费观看| 国产V亚洲V天堂A无码| 91成人免费观看网站| 久久亚洲中文字幕无码| 亚洲中文字幕日产乱码高清app | 亚洲精品伦理熟女国产一区二区| 亚洲 小说区 图片区 都市| a级男女仿爱免费视频| 亚洲一区二区三区在线观看蜜桃| 在线观看国产情趣免费视频| a一级爱做片免费| 亚洲日本在线免费观看| 亚洲成片观看四虎永久| 在线观看免费视频资源| 边摸边吃奶边做爽免费视频网站 | 一级人做人a爰免费视频| 久久国产亚洲精品无码|