`
sxdtzhaoxinguo
  • 浏览: 213560 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

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、在配置文件中做如下的配置就可以了

  1. <actionname="generateChoose"class="com.fzdna.application.agent.actions.admin.manager.numberManager.ChooseNumberAction"
  2. method="generateChoose">
  3. <interceptor-refname="defaultStack"/>
  4. <interceptor-refname="token"/>
  5. <resultname="success">/admin/manager/numberManager/generateChooseNumber.jsp</result>
  6. <resultname="error">/admin/manager/numberManager/generateChooseNumber.jsp</result>
  7. <resultname="invalid.token"type="redirect">generateChooseNumber.do</result>
  8. </action>

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

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

前台jsp页面:

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

js 代码如下:

[javascript]view plaincopy
  1. <mce:scriptlanguage="javascript"><!--
  2. varcheckSubmitFlag=false;
  3. functioncheckSubmit(){
  4. if(checkSubmitFlag==true){
  5. returnfalse;
  6. }
  7. checkSubmitFlag=true;
  8. returntrue;
  9. }
  10. document.ondblclick=functiondocondblclick(){
  11. window.event.returnValue=false;
  12. }
  13. document.onclick=functiondoconclick(){
  14. if(checkSubmitFlag){
  15. window.event.returnValue=false;
  16. }
  17. }
  18. //--></mce:script>

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

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

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics