http://wj131.iteye.com/blog/321720
1、strust1.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
}
}
2、struts2
在strust2防止重复提交
现在还是以新增方法为例子
在后台的action中
//保存方法
public String save() {
//现在要求主键dept中deptid在后台得到。自增,前台不填写
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>
分享到:
相关推荐
在Struts2中,防止重复提交是一个重要的问题,因为它可能导致数据不一致性和服务器资源的浪费。本文将详细介绍如何在Struts2中解决这个问题,以及相关的技术概念。 首先,我们要理解Struts2中的拦截器(Interceptor...
struts2防止表单重复提交,利用struts的拦截器tokenSession,轻轻松松解决表单重复提交的问题。 附件为源代码,后台延迟了3秒,可直接在web服务器下部署运行,输入用户名和密码后,多点几次提交按钮,然后看控制台...
Struts2框架提供了一种解决方案,即使用Token机制来防止表单的重复提交。以下是对这个主题的详细说明: 1. **表单重复提交问题**:当用户在提交表单时,由于网络延迟或用户误操作,可能会导致同一个表单被多次提交...
在Struts的配置文件(例如`struts.xml`)中,为需要防止重复提交的Action添加一个拦截器栈,包括`token`和`tokenSession`拦截器。 ```xml <!-- 配置错误结果页面 --> <param name="includeParams">none ...
struts2 防止 重复 提交 和 等待 画面
Struts2的Token插件是防止重复提交的一种常见方法。这里的"Strut2Token"很可能是指这个插件的应用。它的工作原理是在用户提交表单时生成一个唯一的令牌,并将其存储在服务器端(例如Session)和客户端(通常是隐藏...
令牌机制是Struts框架用于防止表单重复提交的一种手段。其基本原理是在客户端与服务器之间传递一个随机生成的唯一标识符(即令牌),通过对比客户端提交时携带的令牌与服务器端存储的令牌是否一致来判断请求是否有效...
### Struts2防止重复提交的解决方案 #### 一、引言 在Web应用程序开发中,一个常见的问题是如何有效地防止表单的重复提交。这不仅能够提高用户体验,还能增强系统的安全性。Struts2作为一款广泛使用的Java Web应用...
Struts2是一个流行的Java Web框架,它为开发者...通过上述步骤,Struts2的`s:token`标签可以帮助开发者有效地防止重复提交,保证Web应用程序的数据一致性。理解并正确使用这个功能,可以提升应用的健壮性和用户体验。
Struts2提供了一种基于Token的防止重复提交策略。在表单提交时,服务器会生成一个唯一的Token并将其存储在Session中,同时将Token放入到表单中。当用户提交表单时,服务器会检查提交的Token是否与Session中的Token...
Struts框架是一个经典的Java Web开发框架,用于构建MVC(模型-视图-控制器...在实际开发中,除了Struts的令牌机制,还可以结合前端的解决方案,如禁用提交按钮、使用AJAX异步提交等,来进一步增强防止重复提交的效果。
在Struts2框架中,防止重复提交是一个重要的安全性考量,因为重复提交可能导致数据不一致性和资源浪费。在上述描述中,给出了三种主要方法来解决这个问题: 1) **使用 `<s:token>` 标签** Struts2 提供了一个称为 ...
Struts2是一个流行的Java web框架,它...总的来说,Struts2的令牌机制是通过生成和验证令牌来防止重复提交和CSRF攻击的有效方式。开发者应当理解其工作原理,并在需要的地方正确使用,以提高应用程序的安全性和稳定性。
在 Struts2 框架中,防止重复提交是一个非常重要的安全性问题。重复提交可能会导致数据的不一致和系统的不稳定。为了解决这个问题,Struts2 提供了拦截器机制来防止重复提交。在本文中,我们将详细介绍如何设置拦截...
Struts2默认提供了一些拦截器来帮助处理这个问题,但如题目所述,由于性能考虑,项目组决定不使用Struts2的标签,因此需要自定义拦截器来实现防止重复提交的功能。 自定义拦截器的实现主要分为以下几个步骤: 1. *...
总结,Struts2的tokenSession机制是JavaEE Web开发中防止重复提交的有效手段,通过生成并校验token,确保每个请求的唯一性,从而保护了业务数据的完整性。在实际项目中,我们需要正确配置和使用这个机制,以提高应用...
本节主要关注Struts在处理两个关键问题上的高级应用:防止重复提交和文件上传组件的使用。 **一、解决重复提交** 在Web应用程序中,重复提交是一个常见的问题,可能导致数据不一致或服务过载。Struts通过几种策略...
在Web应用中,表单重复...开发者在使用时需要注意配置token相关标签和拦截器,并通过设置正确的结果视图跳转类型来防止因刷新页面导致的重复提交。通过这些方法的合理应用,可以有效地提高Web应用的健壮性和用户体验。