自学Struts2的tokenInterceptor的想法(转载)

 
分类: Struts2 Java JavaScript   991人阅读  评论(4)  收藏  举报
[xml]  view plain copy
 
  1. 本文引用不少网上资料,如没写着引用出处,请原凉。  

先说说tokenInterceptor的作用,防止客户重复提交表单,可以解决,客户在同一表单中点击两个提交,后退后,再提交,在提交完成后,对跳转的页面直接进行刷新,避免两次写入数据库。都可以很好的解决。

先说说什么是拦截器,拦截器,在AOP(Aspect-Oriented Programming)中用于在某个方法或字段被访问之前,进行拦截然后在之前或之后加入某些操作。拦截是AOP的一种实现策略。上面这段话是Max说的。觉得不错,很清晰明了。

我先来举个例子,大家一看就会明白的

struts.xml

[xml]  view plain copy
 
  1. <!DOCTYPE struts PUBLIC   
  2.   
  3.     "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"  
  4.   
  5.     "http://struts.apache.org/dtds/struts-2.0.dtd">  
  6.   
  7. <struts>  
  8.   
  9.     <include file="struts-default.xml"/>  
  10.   
  11.     <package name="default" extends="struts-default">  
  12.   
  13.         <default-interceptor-ref name="paramsPrepareParamsStack"/>  
  14.   
  15.     </package>  
  16.   
  17.     <include file="strutsconfig/struts-workticket.xml" />  
  18.   
  19. </struts>  

struts-workticket.xml

[xml]  view plain copy
 
  1. <!DOCTYPE struts PUBLIC   
  2.   
  3.     "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"  
  4.   
  5.     "http://struts.apache.org/dtds/struts-2.0.dtd">  
  6.   
  7. <struts>  
  8.   
  9.   
  10.   
  11.     <package name="demo" extends="struts-default" namespace="/demo">   
  12.   
  13.        <!-- 错误提示页面 -->  
  14.   
  15.        <global-results>  
  16.   
  17.            <result name="error">/errInfo.jsp</result>  
  18.   
  19.        </global-results>  
  20.   
  21.        <global-exception-mappings>  
  22.   
  23.            <exception-mapping result="error" exception="java.lang.Throwable"/>  
  24.   
  25.        </global-exception-mappings>  
  26.   
  27.          
  28.   
  29.         <action name="tokenInterceptor_*" class="com.hz.struts2.demo.web.action.TokenInterceptorAction" method="{1}">    
  30.   
  31.   
  32.   
  33.             <result name="demo">/web/demo.jsp</result>  
  34.   
  35.             <result name="login">/index.jsp</result>  
  36.   
  37.             <!-- 注意:作用,如果出现重要提交的时候,跳转的页面  -->  
  38.   
  39.             <result name="invalid.token">/overPageInfo.jsp</result>  
  40.   
  41.             <!-- 注意:一定要写上,否则无法运行。原因:如果不写的话, 就不会调用默认的拦截器,因为被覆盖啦 -->   
  42.   
  43.             <interceptor-ref name="defaultStack" />  
  44.   
  45.             <interceptor-ref name="token">  
  46.   
  47.                 <!-- 在action中,需要进行拦截的方法  -->  
  48.   
  49.                 <param name="includeMethods">execute,checkLogin</param>  
  50.   
  51.                 <!-- 在action中,不需要进行拦截的方法  -->  
  52.   
  53.                 <param name="excludeMethods">toLogin</param>  
  54.   
  55.             </interceptor-ref>  
  56.   
  57.               
  58.   
  59.         </action>  
  60.   
  61.   
  62.   
  63.     </package>  
  64.   
  65. </struts>  

com.hz.struts2.demo.web.action.TokenInterceptorAction.java

[java]  view plain copy
 
  1. 这个没什么意思,不需要做任何改动,这就可以体现出拦截器的好出,大大减少啦代码量,提高了代码的复用性。  
[java]  view plain copy
 
  1. package com.hz.struts2.demo.web.action;  
  2.   
  3.   
  4.   
  5. public class TokenInterceptorAction extends AbstractAction {  
  6.   
  7.     @Override  
  8.   
  9.     public String execute() throws Exception {  
  10.   
  11.         System.out.println(" :: execute " + new java.util.Date());  
  12.   
  13.         return "demo";  
  14.   
  15.     }  
  16.   
  17.   
  18.   
  19.     /** 
  20.  
  21.      * Goto login page 
  22.  
  23.      */  
  24.   
  25.   
  26.   
  27.     public String toLogin() throws Exception {  
  28.   
  29.         System.out.println(" :: toLogin " + new java.util.Date());  
  30.   
  31.         //return "invalid.token";  
  32.   
  33.         return "login";  
  34.   
  35.     }  
  36.   
  37.   
  38.   
  39.     public String checkLogin() throws Exception {  
  40.   
  41.         System.out.println(" :: checkLogin " + " " + new java.util.Date());  
  42.   
  43.         return "login";  
  44.   
  45.     }  
  46.   
  47. }  

HTML

[html]  view plain copy
 
  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">  
  2.   
  3. <html>  
  4.   
  5.   <head>  
  6.   
  7.     <title>index</title>  
  8.   
  9.     <script type="text/javascript">  
  10.   
  11.         function submitForm(){  
  12.   
  13.             var url = "/demo/tokenInterceptor_checkLogin.action";  
  14.   
  15.             var token = "struts.token.name=struts.token";  
  16.   
  17.             var token2 = "struts.token=";  
  18.   
  19.             token2 += document.getElementsByName("struts.token")[0].value;  
  20.   
  21.             url += "?" + token + "&";  
  22.   
  23.             url += token2;  
  24.   
  25.             document.location.href = url;  
  26.   
  27.         }  
  28.   
  29.     </script>  
  30.   
  31.   </head>  
  32.   
  33.   
  34.   
  35.   <body>  
  36.   
  37.     <form action="/demo/tokenInterceptor_checkLogin.action" method="post">  
  38.   
  39.         <s:token id="tokenId" />  
  40.   
  41.         <br>  
  42.   
  43.           
  44.   
  45.         <input type="submit">  
  46.   
  47.         <input type="button" onclick="submitForm()" value="非表单提交">  
  48.   
  49.     </form>  
  50.   
  51.   </body>  
  52.   
  53. </html>  

这是有表单的情况,下面提供一段js是没有表单的情况。正好在我系统里用到了这样的需求,一样粘上来这是我做的一个简单的demo,也是一刚开始学的时候,自己学着写的。在这过程中,我过我常容易出现错误的几个问题,都做了记号

总结

要想让自己的技术不会被淘汰,只有靠自己。我想作为一名IT人员都明白一个道理,没有自学能力的人,是没法成为IT精英的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值