用Action.saveToken(request);可能可以:)

解决方案 »

  1.   

    // Prevent unintentional duplication submissions by checking 
    // that we have not received this token previously
            if (!isTokenValid(request)) {
                errors.add(
                    ActionErrors.GLOBAL_ERROR,
                    new ActionError("errors.token"));
            }
            resetToken(request);你可以参考一个例子struts-examples,里面有讲这个的,上面的代码就是判断重复提交的问题
      

  2.   

    *用以下方法可以防止用户回退后再提交.
    1, 使用java提供的方法设置http头信息,在jsp或者servlet中都可以 
    <% 
    response.setHeader("Pragma","No-cache"); 
    response.setHeader("Cache-Control","no-cache"); 
    response.setDateHeader("Expires", 0); 
    %> 
    2, 使用HTML标记,如下: 
    <HEAD> 
    <META HTTP-EQUIV="Pragma" CONTENT="no-cache"> 
    <META HTTP-EQUIV="Cache-Control" CONTENT="no-cache"> 
    <META HTTP-EQUIV="Expires" CONTENT="0"> 
    </HEAD>  
    *在用户submit后用javascript disable 提交按钮,这样可以防止用户不停的点吉或
    按住回车不放造成重复提交的问题.但是用户的浏缆器关闭了javascript就不管用了.*上面都只是在客户端上做了手脚防止用户反复提交,但是不能保证完全可以杜绝这种行为,
    只能是服务器和客户端配合来解决这个问题.我曾经看过一篇文章介绍解决客户重复点击的问题,文章中介绍的方法和Struts中的saveToken方法的原理差不多。它是根据系统时间生成一个随机值,与form中的值同时传到服务器上去,如果客户多次点击,那么就会传回多个随机值,服务器通过比较这个随机值来判断客户是不是多次点击从而可以拒绝多次执行!实际上就是生成一个随机值放在页面里,提交后比较这个值。Struts利用token防止重复提交在编写web应用程序时,经常会遇到这样的情况:由于网速慢等诸多原因,用户刷新了好几次页面,造成多次递交。
    struts中利用token可以来防止这种情况的发生。以增加一本书的纪录举例如下:struts通常鼓励采用这样的流程-- 用 户
    ||
    ||调用
             \/
    EditBookAction
    ||
    ||初始化form并跳转
    \/
    book.jsp
    ||
    ||递交
    \/
    SaveBookAction使用token方法如下--
    a.在EditBookAction中调用saveToken(request)方法。
    b.在SaveBookAction中检验:isTokenValid(request),如为true, resetToken(request).为false按错误处理。代码如下:         if (!isTokenValid(request)) {
            errors.add(ActionErrors.GLOBAL_ERROR,
                   new ActionError("error.transaction.token"));
    }
    resetToken(request);。
      

  3.   

    为什么我怎么样子isTokenValid(request))都是false,它在什么情况下是true
      

  4.   

    我查了下资料,好像form标签必须用struts自带的才可以用isTokenValid检验,有没有不用struts标签检验的方法