详解struts2的token机制和cookie来防止表单重复提交今天在做一个投票系统时要实现防止表单重复提交!当时就想到了用struts2提供的token机制struts2的token机制防止表单重复提交:首先需要在提交的jsp页面(要使用...
详解struts2的token机制和cookie来防止表单重复提交
今天在做一个投票系统时要实现防止表单重复提交!
当时就想到了用struts2提供的token机制
struts2的token机制防止表单重复提交:
首先需要在提交的jsp页面(要使用token机制,必须使用struts2提供的标签库)加上
<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机制来防止表单重复提交还是挺方便的,但是有时却不一定很好的达到我们所需要的目的!
接下来是用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来防止表单重复提交
- SpringBoot使用thymeleaf实现一个前端表格方法详解 2023-06-06
- JSP页面间传值问题实例简析 2023-08-03
- 基于Java Agent的premain方式实现方法耗时监控问题 2023-06-17
- 深入了解Spring的事务传播机制 2023-06-02
- Java实现顺序表的操作详解 2023-05-19
- Java中的日期时间处理及格式化处理 2023-04-18
- Springboot整合minio实现文件服务的教程详解 2022-12-03
- JSP 制作验证码的实例详解 2023-07-30
- ExecutorService Callable Future多线程返回结果原理解析 2023-06-01
- Spring Security权限想要细化到按钮实现示例 2023-03-07