17.3 更强大的tokenSession拦截器
回顾一下上面<s:token/>标签和token拦截器连用,解决了重复提交问题,用法极其简单:Action引用token拦截器,<s:form/>标签内加一个<s:token/>标签,两句话就足以概括,一分钟就足以做完。
但是结果稍稍有点遗憾:对于一次正常提交和一次重复提交,使用token拦截器会使得浏览器最终重定向到invalid.token指定的Result。那么,有没有更好的办法可以让“重复提交”看起来好像没有发生过,浏览器最终跳转到正常提交指定的Result呢?
当然有,而且做法同样简单,把token拦截器换为tokenSession拦截器即可。tokenSession拦截器与token拦截器唯一的不同是在判断某个请求为重复请求之后,并不是立即重定向到名为invalid.token的Result,而是先阻塞这个重复请求,直到浏览器响应最初的正常请求,然后就可以跳转到处理正常请求后的Result了。
因此,只需要修改struts.xml即可,示例如下:
java代码:
- <package name="helloworld" extends="struts-default">
- <action name="tokenAction" class="cn.javass.token.TokenAction">
- <interceptor-ref name="tokenSession"/>
- <interceptor-ref name="defaultStack"/>
- <result>/token/list.jsp</result>
- </action>
- </package>
只做了两点修改:
- 由引用token拦截器变为引用tokenSession拦截器。
- 不再需要名为invalid.token的Result。
再次运行看看,虽然重复提交了,但是仍然正常跳转到success指定的页面了,而且后台也只是处理了一次。
私塾在线网站原创《研磨struts2》系列
转自请注明出处:【http://sishuok.com/forum/blogPost/list/0/4151.html】
欢迎访问http://sishuok.com获取更多内容