`
wj131
  • 浏览: 142714 次
  • 性别: Icon_minigender_1
  • 来自: 西安
社区版块
存档分类
最新评论

struts中防止重复提交的方法

阅读更多

                     Struts的防止重复提交

1strust1.2

struts的保存新增信息:新增信息之后,转到展现页面,但是其实真实的路径还是新增的,而且刚才新增的信息还保存在缓存里面,当刷新的时候,还是会提交数据,就相当于再次新增一次信息。

action里面可以这样定义,来防止重复提交数据:

在准备新增方法里面

public ActionForward presave(ActionMapping mapping, ActionForm form,

                     HttpServletRequest request, HttpServletResponse response)

       {

      This.saveToken(request);//产生一个唯一的Token,把它保存在session

    }

在准备新增页面(请注意该页面最好使用strust1.2的标签)strust标签提交数据

提交到保存方法的时候

 

public ActionForward save(ActionMapping mapping, ActionForm form,

                     HttpServletRequest request, HttpServletResponse response)

       {

      if(this.isTokenValid(request))//验证session里面是否存在一个Token

         //如果有的话,就执行保存

{

            This.get…().save(…..);//保存新增对象的信息

            This.resetToken(request);//取消session中存在的Token

}

}

2struts2

strust2防止重复提交

现在还是以新增方法为例子

在后台的action

//保存方法

public String save() {

              //现在要求主键deptdeptid在后台得到。自增,前台不填写

              Integer max = Collections.max(depts.keySet());//得到Map中键的最大值

              dept.setDeptid(max+1);

              depts.put(dept.getDeptid(), dept);//就是把新增的这个dept添加到Mp中去

              return this.list();//

       }

//list展现方法

       public String list()

       {

         return "page";    

       }

strust.xml文件中

<action name="deptsave" method="save"

                     class="org.www.actions.DeptAction"><!--这里是一个方法对应的一个action-->

                     <interceptor-ref name="token"/>

                     <interceptor-ref name="basicStack"/>

                     <result name="invalid.token" type="chain" > deptlist </result>

<!---这里注意配置的出现重复提交后的异常而配置的转向,这个是转向的另一个action方法。如果转向一个jsp页面就没什么问题。关键是现在再转向到一个action中。那么这个转向的action还要配置一个拦截器-à

 <!--<result name="invalid.token" >/newdept.jsp</result>-à

                     <result name="page" type="chain">deptlist</result>-->

                     <result name="input">/deptnew.jsp</result>

</action>

这里新增的方法配置的拦截器是新增方法。跳转的是用的是”chain”跳转.新增之后就跳转的是list方法

      <!-- 展现方法 -->

              <action name="deptlist" method="list"

                     class="org.www.actions.DeptAction"><!--这里是一个方法对应的一个action-->

                     <interceptor-ref name=" chain "/>

<result name="input">/deptnew.jsp</result>

                     <result name="page">/dept.jsp</result>

              </action>

在新增jsp页面中,要使用strust2的标签<s:token>

 

 

 

 

6
0
分享到:
评论

相关推荐

    Struts2防止重复提交解决方案

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

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

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

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

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

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

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

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

    #### 三、Struts2防止重复提交的方法 在Struts2框架中,防止重复提交可以通过以下几种方式实现: 1. **使用Token机制**: - 在表单中加入一个隐藏字段(如`&lt;s:token /&gt;`),每次提交表单时都会包含这个token值。 ...

    struts2防止重复提交

    Struts2的Token插件是防止重复提交的一种常见方法。这里的"Strut2Token"很可能是指这个插件的应用。它的工作原理是在用户提交表单时生成一个唯一的令牌,并将其存储在服务器端(例如Session)和客户端(通常是隐藏...

    struts2中防止重复提交的方法

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

    Struts2 防重复提交Demo

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

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

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

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

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

    解决在struts 中可以通过token 来重复提交的问题

    ### 解决Struts中通过Token防止重复提交的问题 在Web应用程序开发中,特别是基于MVC架构的框架如Apache Struts中,确保用户操作的安全性是非常重要的。其中一项常见且重要的安全措施是防止表单的重复提交。本文将...

    struts token 防止页面刷新,重复提交

    Token机制是一种常见的防止重复提交的方法,其核心思想是为每一次表单提交生成一个唯一的Token值,并将这个Token值存储在客户端(通常是在表单中作为一个隐藏字段),同时也在服务器端记录该Token值。当表单被提交时...

    解决Struts重复提交

    Struts2提供了一种基于Token的防止重复提交策略。在表单提交时,服务器会生成一个唯一的Token并将其存储在Session中,同时将Token放入到表单中。当用户提交表单时,服务器会检查提交的Token是否与Session中的Token...

    Struts2解决表单重复提交

    Struts2作为一个流行的Java Web框架,为解决表单重复提交提供了多种方法。 首先,关于表单重复提交的原因,有以下几点: 1. 服务器或网络延迟导致用户多次点击提交按钮。 2. 用户在表单提交后刷新浏览器页面。 ...

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

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

    Struts2防止表单重复提交示例

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

    Struts解决重复提交步骤

    令牌机制是Struts框架用于防止表单重复提交的一种手段。其基本原理是在客户端与服务器之间传递一个随机生成的唯一标识符(即令牌),通过对比客户端提交时携带的令牌与服务器端存储的令牌是否一致来判断请求是否有效...

    JavaEE Struts2利用tokenSession防止重复提交

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

Global site tag (gtag.js) - Google Analytics