`
woshixushigang
  • 浏览: 575905 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类

struts2防止重复提交

 
阅读更多

本人负责全国林业行政执法人员管理系统,当时遇到了新增重复提交问题,解决方案如下,一下为部分代码。

newlawpeople.jsp

 <body>
  <div class="table_top"><img src="<%=path %>/images/list_icon.gif">新增人员申请 </div>
  <div align="center" style="width:100%;height:460px;overflow-x:hidden; overflow-y:scroll;">
  <table width="60%" border="0" align="center" cellpadding="0" cellspacing="0" >
  <s:form action="lawpeopleAction!newLawpeople.action" method="post" name="lawpeopleForm" theme="simple" id="lawpeopleForm" enctype="multipart/form-data" target="_self">
  <s:token name="token"></s:token>

 

struts.xml配置

 

<!-- 防止新增执法人员重复提交问题 start -->
   <result name="invalid.token">/tokenfordobule.jsp</result>
   <interceptor-ref name="defaultStack"/>
   <interceptor-ref name="token">
   <param name="includeMethods">newLawpeople</param>
   </interceptor-ref>
   <!-- end -->

 

tokenfordobule.jsp(重复提交后跳转的页面)

 

<body>    
    <font color="#faa112" >对不起,重复提交了!请您别急,
点击<a href="lawpeopleAction!listWaitPeople.action">新增人员申请</a>看看新增的执法人员在不?</br>
如果在表示新增成功,否则请重新<a href="lawpeopleAction!initSelects.action">新增执法人员</a>。</font>
  </body>

 

 

用过struts2的都知道struts2的基石--拦截器。

 

什么是拦截器?

 

拦截器是在action调用前和后执行的 代码。 之所以叫struts2的基石,其实啊struts2框架和核心功能都是通过拦截器完成的。比如我开发中常见的有:类型转换啊,对象封装啊,校验啊,文件上传,文件预装在等等。

 

拦截器能拦截页面嘛?

 

通俗的讲可以,但是大家想想,拦截器拦截的是action,你可以自定拦截器在拦截器类里写处理的代码,实际上拦截的是action。

 

一个action可以配置多个拦截器嘛?

 

当然可以了,每一个拦截器都是相对的一个整体,我们可以为一个action配置多个拦截器。

 

自定了拦截器那默认的拦截器栈呢?

 

如果你自定了拦截器那么默认的拦截器栈就失效了,你可以引用defaultstack。说白了你要用到默认的拦截器栈就得引用。

 

即便是你继承了 struts-default了,你引用的是这个文件中的token 拦截器,那么系统默认引用的defaultstack就失效了。

 

不管是哪个文件里面的,只要你“<interceptor-ref name="xx" />”就覆盖defaultStack了,所以你得重新引用。 

 

如何设定拦截的方法?

 

对于interceptor中的excludeMethods与includeMethods理解。

 

excludeMethods 表示排除指定的方法,即不对标记为excludeMethods的方法进行拦截。

 

includeMethods表示包含指定的方法,即对标记为includeMethods的方法进行拦截

 

在struts.xml中关于excludeMethods和includeMethods有两种实现方式,一种相当于全局,另一种相当于局部,

全局:

<interceptors>
<interceptor name="method"class="com.yxl.interceptor.MethodInterceptor">
<paramname="includeMethods">method1,method2</param>
</interceptor>
</interceptors>

 

局部;

 

<interceptor-refname="method">
<paramname="excludeMethods">method1,method2</param>
</interceptor-ref>

 

全局和局部的param什么时候有效?

 

若全局中的param定义为excludeMethods,同样局部中的param也定义为excludeMethods,则局部中的param生效,全局中的param无效,即被局部中的param覆盖;同样,若全局中的param定义为includeMethods同样局部中的param也定义为includeMethods,则局部中的param生效,全局中的param无效,即被局部中的param覆盖。

当全局中的param与局部中的param不相同的时,即当全局中param为excludeMethods而局部中的param为includeMethods和全局中的param为includeMethods而局部中param为excludeMethods,则标志为includeMethods生效,即若是全局中的param定义为includeMethods,则全局屏蔽局部,以全局为准,反之,以局部为准。

分享到:
评论

相关推荐

    Struts2防止重复提交解决方案

    在Struts2中,防止重复提交是一个重要的问题,因为它可能导致数据不一致性和服务器资源的浪费。本文将详细介绍如何在Struts2中解决这个问题,以及相关的技术概念。 首先,我们要理解Struts2中的拦截器(Interceptor...

    Struts2防止重复提交的解决方案

    ### Struts2防止重复提交的解决方案 #### 一、引言 在Web应用程序开发中,一个常见的问题是如何有效地防止表单的重复提交。这不仅能够提高用户体验,还能增强系统的安全性。Struts2作为一款广泛使用的Java Web应用...

    struts2防止重复提交和等待画面

    struts2 防止 重复 提交 和 等待 画面

    struts2 防止表单重复提交的例子

    Struts2框架提供了一种解决方案,即使用Token机制来防止表单的重复提交。以下是对这个主题的详细说明: 1. **表单重复提交问题**:当用户在提交表单时,由于网络延迟或用户误操作,可能会导致同一个表单被多次提交...

    struts2利用token防止表单重复提交(源代码)

    struts2防止表单重复提交,利用struts的拦截器tokenSession,轻轻松松解决表单重复提交的问题。 附件为源代码,后台延迟了3秒,可直接在web服务器下部署运行,输入用户名和密码后,多点几次提交按钮,然后看控制台...

    Struts2 防重复提交Demo

    Struts2是一个流行的Java Web框架,它为开发者...通过上述步骤,Struts2的`s:token`标签可以帮助开发者有效地防止重复提交,保证Web应用程序的数据一致性。理解并正确使用这个功能,可以提升应用的健壮性和用户体验。

    struts2令牌解决页面重复提交问题

    Struts2是一个流行的Java web框架,它...总的来说,Struts2的令牌机制是通过生成和验证令牌来防止重复提交和CSRF攻击的有效方式。开发者应当理解其工作原理,并在需要的地方正确使用,以提高应用程序的安全性和稳定性。

    Struts2解决表单重复提交

    这样,当发生重复提交时,Struts2框架会自动处理并转向token.jsp页面,提示用户重复提交了表单。 对于第二种原因,即提交表单后刷新浏览器页面导致的重复提交,Struts2框架允许开发者通过配置结果视图的跳转方式来...

    struts2防止表单重复提交--重定向

    服务器端检查这个令牌,如果已经存在,就拒绝处理请求,从而防止重复提交。 - **Session属性**:在Action中设置一个session属性,表示表单已提交。当检测到该属性已存在时,忽略后续的提交请求。 - **客户端验证**...

    struts2中防止重复提交的方法

    在Struts2框架中,防止重复提交是一个重要的安全性考量,因为重复提交可能导致数据不一致性和资源浪费。在上述描述中,给出了三种主要方法来解决这个问题: 1) **使用 `&lt;s:token&gt;` 标签** Struts2 提供了一个称为 ...

    Struts2 表单 重复提交

    "防止表单重复提交 token"是Struts2提供的一种解决方案,通过在请求中加入一个唯一的token来确保请求的唯一性和一致性。 首先,我们来看如何实现这个机制。在Struts2中,我们可以使用拦截器(Interceptor)来实现...

    Struts2防止表单重复提交示例

    在Struts2中防止表单重复提交的过程主要包括以下几个步骤: 1. **生成Token**:当用户发起表单请求时,服务器会生成一个唯一的Token并将其存储在服务器的会话(Session)中,同时将这个Token作为隐藏字段放入到HTML...

    通过xml配置搞定Struts重复提交问题

    在Struts的配置文件(例如`struts.xml`)中,为需要防止重复提交的Action添加一个拦截器栈,包括`token`和`tokenSession`拦截器。 ```xml &lt;!-- 配置错误结果页面 --&gt; &lt;param name="includeParams"&gt;none ...

    Struts2自定义拦截器实现防止重复提交

    Struts2默认提供了一些拦截器来帮助处理这个问题,但如题目所述,由于性能考虑,项目组决定不使用Struts2的标签,因此需要自定义拦截器来实现防止重复提交的功能。 自定义拦截器的实现主要分为以下几个步骤: 1. *...

    struts2实现的简单登陆 附加拦截器防止重复提交

    在这个"struts2实现的简单登陆 附加拦截器防止重复提交"的项目中,我们将深入探讨Struts2如何处理用户登录以及如何通过拦截器来防止重复提交的问题。 首先,我们来理解一下Struts2的核心概念。Struts2框架基于...

    JavaEE Struts2利用tokenSession防止重复提交

    总结,Struts2的tokenSession机制是JavaEE Web开发中防止重复提交的有效手段,通过生成并校验token,确保每个请求的唯一性,从而保护了业务数据的完整性。在实际项目中,我们需要正确配置和使用这个机制,以提高应用...

    Struts2文件上传下载和表单重复提交问题

    对于防止重复提交,可能需要添加`token`或`token-session`拦截器。 5. **安全性考虑** 在实现文件上传和下载时,务必注意安全性问题。比如,防止文件名注入以绕过安全控制,限制上传文件的大小和类型以防止DoS攻击...

Global site tag (gtag.js) - Google Analytics