Struts的防止重复提交
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框架提供了一种解决方案,即使用Token机制来防止表单的重复提交。以下是对这个主题的详细说明: 1. **表单重复提交问题**:当用户在提交表单时,由于网络延迟或用户误操作,可能会导致同一个表单被多次提交...
struts2 防止 重复 提交 和 等待 画面
struts2防止表单重复提交,利用struts的拦截器tokenSession,轻轻松松解决表单重复提交的问题。 附件为源代码,后台延迟了3秒,可直接在web服务器下部署运行,输入用户名和密码后,多点几次提交按钮,然后看控制台...
#### 三、Struts2防止重复提交的方法 在Struts2框架中,防止重复提交可以通过以下几种方式实现: 1. **使用Token机制**: - 在表单中加入一个隐藏字段(如`<s:token />`),每次提交表单时都会包含这个token值。 ...
Struts2的Token插件是防止重复提交的一种常见方法。这里的"Strut2Token"很可能是指这个插件的应用。它的工作原理是在用户提交表单时生成一个唯一的令牌,并将其存储在服务器端(例如Session)和客户端(通常是隐藏...
在Struts2框架中,防止重复提交是一个重要的安全性考量,因为重复提交可能导致数据不一致性和资源浪费。在上述描述中,给出了三种主要方法来解决这个问题: 1) **使用 `<s:token>` 标签** Struts2 提供了一个称为 ...
Struts2是一个流行的Java Web框架,它为开发者...通过上述步骤,Struts2的`s:token`标签可以帮助开发者有效地防止重复提交,保证Web应用程序的数据一致性。理解并正确使用这个功能,可以提升应用的健壮性和用户体验。
在Struts的配置文件(例如`struts.xml`)中,为需要防止重复提交的Action添加一个拦截器栈,包括`token`和`tokenSession`拦截器。 ```xml <!-- 配置错误结果页面 --> <param name="includeParams">none ...
Struts2是一个流行的Java web框架,它...总的来说,Struts2的令牌机制是通过生成和验证令牌来防止重复提交和CSRF攻击的有效方式。开发者应当理解其工作原理,并在需要的地方正确使用,以提高应用程序的安全性和稳定性。
### 解决Struts中通过Token防止重复提交的问题 在Web应用程序开发中,特别是基于MVC架构的框架如Apache Struts中,确保用户操作的安全性是非常重要的。其中一项常见且重要的安全措施是防止表单的重复提交。本文将...
Token机制是一种常见的防止重复提交的方法,其核心思想是为每一次表单提交生成一个唯一的Token值,并将这个Token值存储在客户端(通常是在表单中作为一个隐藏字段),同时也在服务器端记录该Token值。当表单被提交时...
Struts2提供了一种基于Token的防止重复提交策略。在表单提交时,服务器会生成一个唯一的Token并将其存储在Session中,同时将Token放入到表单中。当用户提交表单时,服务器会检查提交的Token是否与Session中的Token...
Struts2作为一个流行的Java Web框架,为解决表单重复提交提供了多种方法。 首先,关于表单重复提交的原因,有以下几点: 1. 服务器或网络延迟导致用户多次点击提交按钮。 2. 用户在表单提交后刷新浏览器页面。 ...
服务器端检查这个令牌,如果已经存在,就拒绝处理请求,从而防止重复提交。 - **Session属性**:在Action中设置一个session属性,表示表单已提交。当检测到该属性已存在时,忽略后续的提交请求。 - **客户端验证**...
在Struts2中防止表单重复提交的过程主要包括以下几个步骤: 1. **生成Token**:当用户发起表单请求时,服务器会生成一个唯一的Token并将其存储在服务器的会话(Session)中,同时将这个Token作为隐藏字段放入到HTML...
令牌机制是Struts框架用于防止表单重复提交的一种手段。其基本原理是在客户端与服务器之间传递一个随机生成的唯一标识符(即令牌),通过对比客户端提交时携带的令牌与服务器端存储的令牌是否一致来判断请求是否有效...
总结,Struts2的tokenSession机制是JavaEE Web开发中防止重复提交的有效手段,通过生成并校验token,确保每个请求的唯一性,从而保护了业务数据的完整性。在实际项目中,我们需要正确配置和使用这个机制,以提高应用...