struts2防止重复提交

struts2的防止重复提交 也使用到了 token (令牌机制),并且使用到了struts2 的一个叫token 的过滤器

 

 

使用方法: 看看我们项目的例子

 

1. 首先在struts的配置文件中 给你的action 加上 token 过滤器

 

 

 

Xml代码 复制代码  收藏代码
  1. <!-- 用户 -->  
  2.      <action name="user" class=" ">  
  3.         <!-- 用户列表 -->  
  4.         <result name="userList">/page/user/userlist.jsp</result>  
  5.         <!-- 添加用户 -->  
  6.             <result name="add">/page/success.jsp</result>  
  7.         <!-- 删除用户 -->  
  8.         <result name="del">user!queryAll.action</result>       
  9.         <!-- 转向修改用户信息 -->  
  10.         <result name="toUpdate">/page/user/updateuser.jsp</result>  
  11.         <!-- 转向添加用户页面 -->  
  12.         <result name="toAdd">/page/user/adduser.jsp</result>  
  13.            
  14.         <!-- 防止重复提交 -->  
  15.         <result name="invalid.token">/page/error.jsp?message=重复提交</result>     
  16.         <interceptor-ref name="defaultStack"/>  
  17.             <interceptor-ref name="token">  
  18.                  <param name="includeMethods">addUser</param>    
  19.             </interceptor-ref>  
  20.                
  21.     </action>  
 <!-- 用户 -->
		 <action name="user" class=" ">
			<!-- 用户列表 -->
			<result name="userList">/page/user/userlist.jsp</result>
			<!-- 添加用户 -->
				<result name="add">/page/success.jsp</result>
			<!-- 删除用户 -->
			<result name="del">user!queryAll.action</result>	
			<!-- 转向修改用户信息 -->
			<result name="toUpdate">/page/user/updateuser.jsp</result>
			<!-- 转向添加用户页面 -->
			<result name="toAdd">/page/user/adduser.jsp</result>
			
			<!-- 防止重复提交 -->
			<result name="invalid.token">/page/error.jsp?message=重复提交</result>  
			<interceptor-ref name="defaultStack"/>
     		<interceptor-ref name="token">
     			 <param name="includeMethods">addUser</param> 
     		</interceptor-ref>
     		
		</action>

 

注意:

a.includeMethods  指定 需要拦截的方法   excludeMethods 指定 不需要拦截的方法 ,多个方法使用 逗号分隔

 

b. 当 拦截器拦截到 当发生重复提交的action 时候 会跳转到 invalid.token 指定的页面

 

c. 为了使用 统一的错误页面,在错误页面上接受到 message 参数的值 可以在 error.jsp 使用 ${param['message']}

 

 

 2. 在提交页面的 form 中增加 <s:token/>  标签  ,需要在页面 中加上

 

<%@ taglib uri="/struts-tags" prefix="s"%>

 

 

 上面的拦截器是局部的拦截器,只对 UserAction 有效,下面 看看我们项目中的全局拦截器的配置例子:

 

 

 

Xml代码 复制代码  收藏代码
  1. <package name="user" extends="struts-default">  
  2.        
  3.         <!-- 用户登录超时过滤器 -->  
  4.         <interceptors>  
  5.             <!-- 自定义session超时过滤器 -->  
  6.             <interceptor name="login"  class="cn.com.xinli.ump.webapp.filter.SessionTimeOutFilter"/>  
  7.             <!-- 过滤器堆栈 -->  
  8.             <interceptor-stack name="myStack">  
  9.                 <!-- 缺省过滤器 -->  
  10.                 <interceptor-ref name="defaultStack"/>  
  11.                 <!-- session超时过滤器 -->  
  12.                 <interceptor-ref name="login"/>  
  13.                 <!-- 重复提交过滤器 -->  
  14.             <interceptor-ref name="token">  
  15.                  <param name="includeMethods">addUser</param>    
  16.             </interceptor-ref>  
  17.             </interceptor-stack>  
  18.         </interceptors>  
  19.         <!-- 设置默认顾虑器 -->  
  20.         <default-interceptor-ref name="myStack"/>  

http://8366.iteye.com/blog/565538

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值