Spring filter和拦截器(Interceptor)的区别和执行顺序

转载自:http://listenup.iteye.com/blog/1559553

1.Filter过滤器只过滤jsp文件不过滤action请求解决方案

解决办法:在web.xml中将filter的配置放在struts2配置的前面。

2.拦截器与Filter的区别 

Spring的拦截器与Servlet的Filter有相似之处,比如二者都是AOP编程思想的体现,都能实现权限检查、日志记录等。不同的是:


使用范围不同:Filter是Servlet规范规定的,只能用于Web程序中。而拦截器既可以用于Web程序,也可以用于Application、Swing程序中。


规范不同:Filter是在Servlet规范中定义的,是Servlet容器支持的。而拦截器是在Spring容器内的,是Spring框架支持的。


使用的资源不同:同其他的代码块一样,拦截器也是一个Spring的组件,归Spring管理,配置在Spring文件中,因此能使用Spring里的任何资源、对象,例如Service对象、数据源、事务管理等,通过IoC注入到拦截器即可;而Filter则不能。


深度不同:Filter在只在Servlet前后起作用。而拦截器能够深入到方法前后、异常抛出前后等,因此拦截器的使用具有更大的弹性。所以在Spring构架的程序中,要优先使用拦截器。


实际上Filter和Servlet极其相似,区别只是Filter不能直接对用户生成响应。实际上Filter里doFilter()方法里的代码就是从多个Servlet的service()方法里抽取的通用代码,通过使用Filter可以实现更好的复用。 

filter是一个可以复用的代码片段,可以用来转换HTTP请求、响应和头信息。Filter不像Servlet,它不能产生一个请求或者响应,它只是修改对某一资源的请求,或者修改从某一的响应。  

JSR中说明的是,按照多个匹配的Filter,是按照其在web.xml中配置的顺序来执行的。 

所以这也就是,把自己的Filter或者其他的Filter(比如UrlRewrite的Filter)放在Struts的DispatcherFilter的前面的原因。因为,它们需要在请求被Struts2框架处理之前,做一些前置的工作。 

当Filter被调用,并且进入了Struts2的DispatcherFilter中后,Struts2会按照在Action中配置的Interceptor Stack中的Interceptor的顺序,来调用Interceptor。 

3.servlet、filter、interceptor的执行顺序

[java]  view plain  copy
  1. @Override    
  2.     public void doFilter(ServletRequest servletrequest,    
  3.             ServletResponse servletresponse, FilterChain filterchain)    
  4.             throws IOException, ServletException {    
  5.         System.out.println("in  filter 1.");    
  6.         filterchain.doFilter(servletrequest, servletresponse);    
  7.         System.out.println("outing filter 1");    
  8.     }    

   interceptor代码:

[java]  view plain  copy
  1. public String intercept(ActionInvocation actioninvocation) throws Exception {    
  2.     System.out.println("in logininterceptor");    
  3.     String result=actioninvocation.invoke();    
  4.     System.out.println("outing logininterceptor");    
  5.     return result;    
  6. }    

    action代码:

[java]  view plain  copy
  1. @Override      
  2. public String execute() throws Exception {      
  3.     System.out.println("in loginaciton");    
  4.     ActionContext context=ActionContext.getContext();    
  5.     Map<String, Object> session=context.getSession();     
  6.     session.put("userName", userName);      
  7.         
  8.     /* HttpServletRequest request = ServletActionContext.getRequest();  
  9.     HttpSession session = request.getSession();  
  10.     session.putValue("userName", userName);*/    
  11.     System.out.println("outing loginaciton");    
  12.     return SUCCESS;      
  13. }     

   jsp代码:

[html]  view plain  copy
  1. <script type="text/javascript">       
  2.    function submitForm(){    
  3.       document.getElementById("form1").submit();     
  4.    }    
  5. </script>    
  6.     
  7. </head>    
  8.      
  9.  <body>    
  10.    This is Login page. <br>    
  11.    <form action="<%=path %>/login2.action" method="post" id="form1" name="form1">    
  12.       UserName:<input type="text" id="userName" name="userName"/><input type="button" value="submit" onclick="submitForm()" id="submit1" />    
  13.    </form>    
  14.  </body>    

   struts.xml

[html]  view plain  copy
  1. <struts>    
  2. <package name="default" extends="struts-default" namespace="/">      
  3.              
  4.         <interceptors>    
  5.             <interceptor name="MyInterceptor" class="Login.LoginInterceptor"></interceptor>    
  6.             <interceptor-stack name="myInterceptorStack">    
  7.                 <interceptor-ref name="MyInterceptor"/>    
  8.                 <interceptor-ref name="defaultStack"/>    
  9.             </interceptor-stack>    
  10.         </interceptors>    
  11.              
  12.         <action name="login2" class="Login.LoginAction">      
  13.                 <result name="success">      
  14.                    /Login/success.jsp      
  15.                 </result>    
  16.                 <interceptor-ref name="myInterceptorStack"></interceptor-ref>    
  17.         </action>      
  18.      
  19. </package>    
  20. </struts>  

console:

[html]  view plain  copy
  1. in  filter 1.  
  2. in logininterceptor  
  3. in loginaciton  
  4. outing loginaciton  
  5. outing logininterceptor  
  6. outing filter 1  

3.servlet、filter的执行顺序

servlet代码:

[java]  view plain  copy
  1. public void init() throws ServletException {     
  2.     System.out.println("servlet初始化");    
  3. }     
  4.     
  5. public void doPost(HttpServletRequest request, HttpServletResponse response)            
  6. throws ServletException, IOException {     
  7.     System.out.println("in servlet");    
  8.     response.setContentType("text/html");     
  9.     PrintWriter out = response.getWriter();     
  10.     out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01 Transitional//EN\">");     
  11.     out.println("<HTML>");     
  12.     out.println("    <HEAD><TITLE>A Servlet</TITLE></HEAD>");     
  13.     out.println("    <BODY>");     
  14.     out.print("        This is ");     
  15.     out.print(this.getClass());     
  16.     out.println(", using the POST method");          
  17.          
  18.     out.println("<br>");     
  19.     String x = request.getParameter("x");     
  20.     String y = request.getParameter("y");     
  21.     out.println("x="+x);     
  22.     out.println("<br>");     
  23.     out.println("y="+y);     
  24.     out.println("<br>");     
  25.          
  26.     out.println("    </BODY>");     
  27.     out.println("</HTML>");     
  28.     out.flush();     
  29.     out.close();     
  30.     System.out.println("outing servlet");    
  31.   }     
  32.    
  33. public void destroy(){          
  34.     System.out.println("servlet销毁");    
  35.     super.destroy();    
  36. }    

 console:

[html]  view plain  copy
  1. servlet初始化  
  2. in  filter 1.  
  3. in servlet  
  4. before HttpServletRequest  
  5. after HttpServletRequest  
  6. outing servlet  
  7. outing filter 1  
  8. 当tomcat容器停止的时候,输出:servlet销毁  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值