詳解struts2的token機制和cookie來防止表單重復(fù)提交
詳解struts2的token機制和cookie來防止表單重復(fù)提交
今天在做一個投票系統(tǒng)時要實現(xiàn)防止表單重復(fù)提交!
當(dāng)時就想到了用struts2提供的token機制
struts2的token機制防止表單重復(fù)提交:
首先需要在提交的jsp頁面(要使用token機制,必須使用struts2提供的標(biāo)簽庫)加上
<s:token></s:token>
這段代碼,然后在struts.xml里面需要進行如下配置:
<action name="token" class="com.xiaoluo.struts2.TokenAction"> <result name="success">/tokenSuccess.jsp</result> <result name="invalid.token">/tokenFail.jsp</result> //name必須是invalid.token <interceptor-ref name="token"></interceptor-ref> <interceptor-ref name="defaultStack"></interceptor-ref> </action>
總的來說,struts2提供的token機制來防止表單重復(fù)提交還是挺方便的,但是有時卻不一定很好的達到我們所需要的目的!
接下來是用cookie來防止表單重復(fù)提交,就拿今天做的投票系統(tǒng)的例子來說,通過將 每個投票選項的id以及"hasVote" + id的組合放到cookie里面,然后根據(jù)所需設(shè)置cookie存活時間,然后放到response里面,然后在處理投票的action里首先判斷 cookie中的name是否是已經(jīng)投過票的名稱,如果是就重定向到重復(fù)提交頁面!
Cookie[] cookies = request.getCookies(); for(Cookie cookie : cookies) { if(String.valueOf(vote.getId()).equals(cookie.getValue())) { response.sendRedirect("repeatSubmit.jsp"); } else { Cookie cookie2 = new Cookie("hasVote" + vote.getId(), String.valueOf(vote.getId())); response.addCookie(cookie2); } }
我覺得cookie的這種方法更加實用一些,在實際中根據(jù)自己情況自行選擇方式吧!
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
JSP中用回車監(jiān)聽按鈕事件兼容火狐 IE等主流瀏覽器
這篇文章主要介紹了用回車監(jiān)聽按鈕事件并且兼容火狐、IE等主流瀏覽器 ,需要的朋友可以參考下2014-04-04JSP頁面IE無法打開Internet 站點…… 已終止操作 的解決方法
今天機緣巧合之下遇到了個人認為比較經(jīng)典的“IE無法打開Internet 站點…… 已終止操作”的問題。2013-05-05