【Struts2】防止表单重复提交

一、概述

  • regist.jsp----->RegistServlet
  • 表单重复提交 危害: 刷票、 重复注册、带来服务器访问压力(拒绝服务)
  • 解决方案:
    • 在页面上生成一个令牌(就是一个随机字符串),将其存储到session中,并在表单中携带.
    • 在服务器端,获取数据时,也将令牌获取,将它与session中存储的token对比,没问题,将session中令牌删除。

二、Struts2中解决方案

  • struts2中怎样解决表单重复提交:
  • 在struts2中解决表单重复提交,可以使用它定义的一个interceptor。
    xml <interceptor name="token" class="org.apache.struts2.interceptor.TokenInterceptor"/>

三、实现步骤

  • 1.在页面上需要使用一个token tag,在表单中添加一个标签 <s:token/> ,就会在页面上生成一个令牌,并存在于表单中。
  • 2.需要在action中引入token拦截器 <interceptor-ref name="token"/>
  • 3.需要配置视图
    • <result name="invalid.token">/token.jsp</result>
    • 通过 显示错误信息
    • 覆盖重复提交信息 struts.messages.invalid.token=您已经重复提交表单,请刷新后重试

猜你喜欢

转载自www.cnblogs.com/haoworld/p/struts2-fang-zhi-biao-dan-zhong-fu-ti-jiao.html
今日推荐