详解struts2的token机制和cookie来防止表单重复提交
程序开发好之后,都要测试无误后才能上线,struts2的token机制其实并没有我们想象的那么简单,有时候需要修改参数进行设置,下文是详解struts2的token机制和cookie来防止表单重复提交介绍,跟随爱站技术频道小编一起看下吧。
详解struts2的token机制和cookie来防止表单重复提交
今天在做一个投票系统时要实现防止表单重复提交!
当时就想到了用struts2提供的token机制
struts2的token机制防止表单重复提交:
首先需要在提交的jsp页面(要使用token机制,必须使用struts2提供的标签库)加上
这段代码,然后在struts.xml里面需要进行如下配置:
/tokenSuccess.jsp /tokenFail.jsp //name必须是invalid.token
总的来说,struts2提供的token机制来防止表单重复提交还是挺方便的,但是有时却不一定很好的达到我们所需要的目的!
接下来是用cookie来防止表单重复提交,就拿今天做的投票系统的例子来说,通过将 每个投票选项的id以及"hasVote" + id的组合放到cookie里面,然后根据所需设置cookie存活时间,然后放到response里面,然后在处理投票的action里首先判断 cookie中的name是否是已经投过票的名称,如果是就重定向到重复提交页面!
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的这种方法更加实用一些,在实际中根据自己情况自行选择方式吧!
以上是爱站技术频道小编介绍的详解struts2的token机制和cookie来防止表单重复提交,JSP的开发要保证项目的安全,这也可以保证开发的顺利进行。
上一篇:Jsp敏感词过滤的示例代码
下一篇:用简单代码实现文件上传的方法