java 防止表单重复提交

防止表单重复提交,或者是防止按F5 刷新提交表单。

       在WEB开发中是经常会碰到这样的问题的。

   目前主流的解决方法有以下三种:

    1、采用脚本来解决

    2、重定向到别的页面

    3、使用s:token 标签

   

   由于我是使用S2SH来开发的,所以就选择了第三种方法。

     先简单的解释下<s:token  /> 这个标签,<s:token>就是为了防止Struts2中表单重复提交的。他的实现类是org.apache.struts2.views.jsp.ui.TokenTag,继承于org.apache.struts2.views.jsp.ComponentTagSupport。

TokenTag ComponentTagSupport.doStartTag 将控件对象化
TokenTag ComponentTagSupport.doEndTag component.end 调用component(Token)
Token 继承自org.apache.struts2.components.UIBean,因此首先调用UIBean.end方法,在UIBean.end方法中最后一句调用定义为protected的方法evaluateExtraParams,这个方法是提供给UIBean的子类扩展使用的,在Token的evaluateExtraParams方法中
String token = buildToken(tokenName);
其中buildToken方法实际上调用的是 TokenHelper.setToken方法,在setToken方法中值得注意的是两点,
1、 generateGUID()方法,此方法是生成Token值得算法所在
2 、session.put(tokenName, token)可以看到此处将生成的值存储在session中,等待以后比对。

生成guid后,token拦截器会判断客户端form提交的token和session中保存的session是否equals。如果equals则执行Action。否则拦截器直接返回invaid.token结果,Action对应的方法也不会执行

 所以我解决的方法是:

   1、前台jsp 表单在提交(</form>)之前,加入<s:token />标签,action中不需要做修改。

   2、在配置文件中做如下的配置就可以了

  

[java]  view plain copy
  1. <action name="generateChoose" class="com.fzdna.application.agent.actions.admin.manager.numberManager.ChooseNumberAction"  
  2.             method="generateChoose">   
  3.             <interceptor-ref name="defaultStack" />    
  4.             <interceptor-ref name="token" />    
  5.             <result name="success">/admin/manager/numberManager/generateChooseNumber.jsp</result>  
  6.             <result name="error">/admin/manager/numberManager/generateChooseNumber.jsp</result>  
  7.             <result name="invalid.token" type="redirect">generateChooseNumber.do</result>  
  8.          </action>  

 这样就可以防止表单重复提交。

 

   再简单说下采用脚本控制,这中方式本来就存在缺陷,如果客服端禁止使用脚本,即使你的脚本写的再好,也是白费。个人建议还是在服务器端进行控制。

  前台jsp页面:

  <form action="duplicateAction.do" method="post" οnsubmit="return checkSubmit();"></form>

 js 代码如下:

  

[javascript]  view plain copy
  1. <mce:script language="javascript"><!--  
  2.       
  3.     var checkSubmitFlag = false;      
  4.     function checkSubmit() {      
  5.       if (checkSubmitFlag == true) {      
  6.          return false;      
  7.       }      
  8.       checkSubmitFlag = true;      
  9.       return true;      
  10.    }      
  11.    document.ondblclick = function docondblclick() {      
  12.     window.event.returnValue = false;      
  13.    }      
  14.    document.onclick = function doconclick() {      
  15.        if (checkSubmitFlag) {      
  16.          window.event.returnValue = false;      
  17.        }      
  18.    }      
  19. // --></mce:script>   
  

 

至于跳到中转页面,也就是在表单提交的时候跳转到一个中转的jsp页面即可。

借助于网上达人的意见,及个人的体会,简单总结下。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

迷彩的博客

你的鼓励将是我最大的创作动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值