当前位置: 代码迷 >> JavaScript >> JSP(Struts)避免Form重复提交的几种草案
  详细解决方案

JSP(Struts)避免Form重复提交的几种草案

热度:419   发布时间:2012-10-28 09:54:44.0
JSP(Struts)避免Form重复提交的几种方案

1 javascript ,设置一个变量,只允许提交一次。

  1. <script?language="javascript">? ??
  2.   ?var?checkSubmitFlg?=?false;? ??
  3.   ?function?checkSubmit()?{? ??
  4.   ?if?(checkSubmitFlg?==?true)?{? ??
  5.   ?return?false;? ??
  6.   ?}? ??
  7.   ?checkSubmitFlg?=?true;? ??
  8.   ?return?true;? ??
  9.   ?}? ??
  10.   ?document.ondblclick?=?function?docondblclick()?{? ??
  11.   ?window.event.returnValue?=?false;? ??
  12.   ?}? ??
  13.   ?document.onclick?=?function?doconclick()?{? ??
  14.   ?if?(checkSubmitFlg)?{? ??
  15.   ?window.event.returnValue?=?false;? ??
  16.   ?}? ??
  17.   ?}? ??
  18.   script>? ??
  19.   ? ??
  20.   <html:form?action="myAction.do"?method="post"?onsubmit="return?checkSubmit();">??

2 还是javascript,将提交按钮或者image置为disable  ?
  1. <html:form?action="myAction.do"?method="post"? ??
  2.   ?onsubmit="getElById('submitInput').disabled?=?true;?return?true;">?  ? ??
  3.   ?<html:image?styleId="submitInput"?src="http://www.rdxx.com/Files/Pic/2007-7/4/HKDJF7EDAA0858I8KC.gif"?border="0"?/> ? ??
  4. html:form> ??
?
3 利用struts的同步令牌机制  ?
  利用同步令牌(Token)机制来解决Web应用中重复提交的问题,Struts也给出了一个参考实现。?
  基本原理: ?
  服务器端在处理到达的请求之前,会将请求中包含的令牌值与保存在当前用户会话中的令牌值进行比较,看是否匹配。在处理完该请求后,且在答复发送给客户端之前,将会产生一个新的令牌,该令牌除传给客户端以外,也会将用户会话中保存的旧的令牌进行替换。这样如果用户回退到刚才的提交页面并再次提交的话,客户端传过来的令牌就和服务器端的令牌不一致,从而有效地防止了重复提交的发生。 ?
  if (isTokenValid(request, true)) {?
   // your code here?
   return mapping.findForward("success");?
  } else {?
   saveToken(request);?
   return mapping.findForward("submitagain");?
  } ?
  Struts根据用户会话ID和当前系统时间来生成一个唯一(对于每个会话)令牌的,具体实现可以参考TokenProcessor类中的generateToken()方法。  ?
  1. //验证事务控制令牌, <html:form> 会自动根据session中标识生成一个隐含input代表令牌,防止两次提交?
  2. 在action中:  ?
  1. //<input?type="hidden"?name="org.apache.struts.taglib.html.TOKEN"? ??
  2.   ?//?value="6aa35341f25184fd996c4c918255c3ae">? ??
  3.   ?if?(!isTokenValid(request))? ??
  4. errors.add(ActionErrors.GLOBAL_ERROR,? ??
  5.   ?new?ActionError("error.transaction.token"));? ??
  6.   ?resetToken(request);?//删除session中的令牌  ? ??
  7.   3.?action有这样的一个方法生成令牌  ? ??
  8.   ?protected?String?generateToken(HttpServletRequest?request)?{  ? ??
  9.   ?HttpSession?session?=?request.getSession();? ??
  10.   ?try?{? ??
  11.   ?byte?id[]?=?session.getId().getBytes();? ??
  12.   ?byte?now[]?=? ??
  13.   ?new?Long(System.currentTimeMillis()).toString().getBytes();? ??
  14.   ?MessageDigest?md?=?MessageDigest.getInstance("MD5");? ??
  15.   ?md.update(id);? ??
  16.   ?md.update(now);? ??
  17.   ?return?(toHex(md.digest()));? ??
  18.   ?}?catch?(IllegalStateException?e)?{? ??
  19.   ?return?(null);? ??
  20.   ?}?catch?(NoSuchAlgorithmException?e)?{? ??
  21.   ?return?(null);? ??
  22.   ?}? ??
  23.   ?}??
?
在更新的时候防止按钮重复点击,主要是用Session来做判断
在JSP/Servlet中可以
JSP页面
  1. <input?type="hidden?"?name="??"?value?="?"?>???

SynchroToken.java
package com.lims.util;
import org.apache.struts.util.*;
import javax.servlet.http.*;
import javax.servlet.jsp.*;
import org.apache.struts.action.*;
/**
? *

Title: SynchroToken


? *

Description:


? *

Copyright: Copyright (c) 2004


? *

Company: NetStar


? * @author Jstar
? * @version 1.0
? * Created in 2004/04/21
? */
public class SynchroToken{
?public final static java.lang.String TOKEN_NAME = "_token";
?public static boolean checkToken (HttpServletRequest request){
?? boolean isEqual = false;
?? HttpSession session = request.getSession ();
?? String formToken = request.getParameter (TOKEN_NAME);
?? String sessionToken = (String)session.getAttribute (TOKEN_NAME);
?? System.out.println ("formToken: " + formToken + " sessionToken: " +
?????????????????????? sessionToken);
?? if (formToken != null && sessionToken == null){
???? session.setAttribute (TOKEN_NAME, formToken);
???? isEqual = true;
?? }
?? return isEqual;
?}
?/**
? * Insert the method's description here.
? * Creation date: (4/19/2004 3:23:25 PM)
? * @return java.lang.String
? * @param request javax.servlet.http.HttpServletRequest
? */
?public static String getToken (HttpServletRequest request){
?? String token = "" + System.currentTimeMillis ();
?? HttpSession session = request.getSession ();
?? if (session != null){
???? session.removeAttribute (TOKEN_NAME);
?? }
?? return token;z
?}
?/**
? * Insert the method's description here.
? * Creation date: (4/19/2004 3:24:10 PM)
? * @return java.lang.String
? */
?final static java.lang.String getTOKEN_NAME (){
?? return TOKEN_NAME;
?}
?public static String message (PageContext pageContext, String key) throws
???? JspException{
?? return RequestUtils.message (pageContext, null, null, key);
?}
}

?

4 添加中转页面

</html:form>

  相关解决方案