詳解struts2的token機(jī)制和cookie來防止表單重復(fù)提交
今天在做一個(gè)投票系統(tǒng)時(shí)要實(shí)現(xiàn)防止表單重復(fù)提交!
當(dāng)時(shí)就想到了用struts2提供的token機(jī)制
struts2的token機(jī)制防止表單重復(fù)提交:
首先需要在提交的jsp頁(yè)面(要使用token機(jī)制,必須使用struts2提供的標(biāo)簽庫(kù))加上
這段代碼,然后在struts.xml里面需要進(jìn)行如下配置:
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機(jī)制來防止表單重復(fù)提交還是挺方便的,但是有時(shí)卻不一定很好的達(dá)到我們所需要的目的!
接下來是用cookie來防止表單重復(fù)提交,就拿今天做的投票系統(tǒng)的例子來說,通過將 每個(gè)投票選項(xiàng)的id以及"hasVote" + id的組合放到cookie里面,然后根據(jù)所需設(shè)置cookie存活時(shí)間,然后放到response里面,然后在處理投票的action里首先判斷 cookie中的name是否是已經(jīng)投過票的名稱,如果是就重定向到重復(fù)提交頁(yè)面!
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的這種方法更加實(shí)用一些,在實(shí)際中根據(jù)自己情況自行選擇方式吧!
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
您可能感興趣的文章:- 簡(jiǎn)單談?wù)凷truts動(dòng)態(tài)表單(DynamicForm)
- Struts2中接收表單數(shù)據(jù)的三種驅(qū)動(dòng)方式
- J2EE中的struts2表單細(xì)節(jié)處理
- Struts2中Action三種接收參數(shù)形式與簡(jiǎn)單的表單驗(yàn)證功能
- Java的Struts框架中登陸功能的實(shí)現(xiàn)和表單處理器的使用
- 通過Ajax兩種方式講解Struts2接收數(shù)組表單的方法
- struts2中一個(gè)表單中提交多個(gè)請(qǐng)求的例子(多個(gè)提交按鈕)
- 基于Struts2實(shí)現(xiàn)防止表單重復(fù)提交