Struts2 <s:token/>标签 防止表单多次提交 _MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 1794 | 回复: 0   主题: Struts2 <s:token/>标签 防止表单多次提交         下一篇 
johnnyfox
注册用户
等级:新兵
经验:41
发帖:90
精华:0
注册:2011-12-12
状态:离线
发送短消息息给johnnyfox 加好友    发送短消息息给johnnyfox 发消息
发表于: IP:您无权察看 2015-4-10 9:22:02 | [全部帖] [楼主帖] 楼主

  1. 1、使用Struts2的表单标签,其中需要增加token标签。如下:  
  2. ……  
  3. Java代码  
  4. <%@ taglib uri="/struts-tags" prefix="s" %>    
  5. ……    
  6. <s:form action="page1" theme="simple">    
  7. <s:datetimepicker name="order.date" label="购买日期" toggleType="explode" value="today"/><br/>    
  8. <s:token/>    
  9. <s:reset/><s:submit/>    
  10.   </s:form>   
  11. <%@ taglib uri="/struts-tags" prefix="s" %>  
  12. ……  
  13. <s:form action="page1" theme="simple">  
  14. <s:datetimepicker name="order.date" label="购买日期" toggleType="explode" value="today"/><br/>  
  15. <s:token/>  
  16. <s:reset/><s:submit/>  
  17.    </s:form>  
  18. 2、在struts配置文件中增加token拦截器。如下:  
  19. Java代码  
  20. <?xml version="1.0" encoding="UTF-8"?>    
  21. <!DOCTYPE struts PUBLIC    
  22. "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"   
  23. "http://struts.apache.org/dtds/struts-2.0.dtd">    
  24. <struts>    
  25. <package name="lee" extends="struts-default">    
  26. <action name="page1" class="org.bruce.Page1">    
  27. <interceptor-ref name="defaultStack" />    
  28. <interceptor-ref name="token" />    
  29. <result>/page1.jsp</result>    
  30. <result name="invalid.token">/page1error.jsp</result>    
  31. </action>    
  32. </package>    
  33. </struts>   
  34. <?xml version="1.0" encoding="UTF-8"?>  
  35. <!DOCTYPE struts PUBLIC  
  36. "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"  
  37. "http://struts.apache.org/dtds/struts-2.0.dtd">  
  38. <struts>  
  39. <package name="lee" extends="struts-default">  
  40. <action name="page1" class="org.bruce.Page1">  
  41. <interceptor-ref name="defaultStack" />  
  42. <interceptor-ref name="token" />  
  43. <result>/page1.jsp</result>  
  44. <result name="invalid.token">/page1error.jsp</result>  
  45. </action>  
  46. </package>  
  47. </struts>注意,需要name为invaid.token的result。这是当拦截器判断是重复提交的时候,会转向的结果。  
  48. 3、invaid.token页面打印错误信息,一样可以使用struts标签。如下:  
  49. <s:actionerror/>  
  50. 理解:  
  51. 1、JSP使用<s:token/>标签的时候,Struts2会建立一个GUID(全局唯一的字符串)放在session中,并且会成为一个hidden放在form中。  
  52. 2、token拦截器会判断客户端form提交的token和session中保存的session是否equals。如果equals则执行Action。否则拦截器直接返回invaid.token结果,Action对应的方法也不会执行  
  53. ---------------------------------------------------------------------------------  
  54. 对于采用token防止表单重复提交的原理我就不用多说了,大家也应该都知道,在这我只介绍在struts2中如何利用标签实现防止表单的重复提交。     
  55.   首先在表单中加入标签 ,会生成一个隐藏域用于存储系统自动随机生成的token值。然后在action中启用TokenInterceptor,即在struts.xml中加入下面类似代码。  
  56. Java代码  
  57.   1.<action name="register" class="UserAction" method="register">   
  58.   2.   <result>register_success.jsp</result>   
  59.   3.   <result name="input">register.jsp</result>   
  60.   4.   <result name="invalid.token">register.jsp</result>   
  61.   5.   <interceptor-ref name="token"></interceptor-ref>   
  62.   6.   <interceptor-ref name="defaultStack"></interceptor-ref>   
  63.   7. </action>        
  64. <action name="register" class="UserAction" method="register">  
  65. <result>register_success.jsp</result>  
  66. <result name="input">register.jsp</result>  
  67. <result name="invalid.token">register.jsp</result>  
  68. <interceptor-ref name="token"></interceptor-ref>  
  69. <interceptor-ref name="defaultStack"></interceptor-ref>  
  70. </action>  
  71.   其中<result name="invalid.token">register.jsp</result>”是在发生表单重复提交时,返回给用户提示信息的显示页面,同时还需在显示页面中加入 ;“<interceptor-ref name="token"></interceptor-ref>”是启用TokenInterceptor 如果表单重复提交,会提示The form has already been processed or no token was supplied, please try again。修改国际化文件struts.messages.invalid.token 的键值,提供自己定制的错误信息。比如:struts.messages.invalid.token= 您已经提交了表单,请不要重复提交。  

--转自 北京联动北方科技有限公司




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论