Spring MVC 拦截器

<?xml version="1.0" encoding="UTF-8"?>  

 <beans xmlns="http://www.springframework.org/schema/beans" 

     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 

     xmlns:tx="http://www.springframework.org/schema/tx" 

     xmlns:context="http://www.springframework.org/schema/context" 

     xmlns:aop="http://www.springframework.org/schema/aop" 

     xmlns:mvc="http://www.springframework.org/schema/mvc" 

     xsi:schemaLocation="  

        http://www.springframework.org/schema/beans  

        http://www.springframework.org/schema/beans/spring-beans-3.0.xsd  

        http://www.springframework.org/schema/context  

        http://www.springframework.org/schema/context/spring-context-3.0.xsd  

        http://www.springframework.org/schema/tx  

        http://www.springframework.org/schema/tx/spring-tx-3.0.xsd  

        http://www.springframework.org/schema/mvc        

        http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd    

        http://www.springframework.org/schema/aop  

        http://www.springframework.org/schema/aop/spring-aop-2.5.xsd"  

        >  

        

        

     <mvc:interceptors>    

        <mvc:interceptor>    

            <mvc:mapping path="/**"/>    <!--需要拦截的ACTION 如 /deskTop/wxcsmain.do-->

            <bean class="com.xx.space.backstage.interceptor.CommonInterceptor" />    

        </mvc:interceptor>    

     </mvc:interceptors>   

        

 </beans> 

package com.xx.space.backstage.interceptor;  

    

 import javax.servlet.http.HttpServletRequest;  

 import javax.servlet.http.HttpServletResponse;  

    

 import org.apache.log4j.Logger;  

 import org.springframework.web.servlet.ModelAndView;  

 import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;  

 import org.springframework.web.servlet.handler.SimpleUrlHandlerMapping;  

 import org.springframework.web.servlet.mvc.support.ControllerClassNameHandlerMapping;  

    


 public class CommonInterceptor extends HandlerInterceptorAdapter {  

     private Logger log = Logger.getLogger(CommonInterceptor.class);  

    

     public CommonInterceptor() {}  

    

     /**  

      * 在业务处理器处理请求之前被调用 如果返回false 从当前的拦截器往回执行所有拦截器的afterCompletion(),再退出拦截器链  

      *   

      * 如果返回true 执行下一个拦截器,直到所有的拦截器都执行完毕 再执行被拦截的Controller 然后进入拦截器链,  

      * 从最后一个拦截器往回执行所有的postHandle() 接着再从最后一个拦截器往回执行所有的afterCompletion()  

      */ 

     @Override 

     public boolean preHandle(HttpServletRequest request,  

             HttpServletResponse response, Object handler) throws Exception {  

         System.out.println("CommonInterceptor拦截器: preHandle");  

         return true;  

     }  

    

     // 在业务处理器处理请求执行完成后,生成视图之前执行的动作  

     @Override 

     public void postHandle(HttpServletRequest request,  

             HttpServletResponse response,   

             Object handler,ModelAndView modelAndView) throws Exception {  

         System.out.println("CommonInterceptor拦截器: postHandle");  

         SimpleUrlHandlerMapping dd;  

         ControllerClassNameHandlerMapping ee;  

     }  

    

     /**  

      * 在DispatcherServlet完全处理完请求后被调用  

      *   

      * 当有拦截器抛出异常时,会从当前拦截器往回执行所有的拦截器的afterCompletion()  

      */ 

     @Override 

     public void afterCompletion(HttpServletRequest request,  

             HttpServletResponse response, Object handler, Exception ex)  

             throws Exception {  

         System.out.println("CommonInterceptor拦截器: afterCompletion");  

     }  

        

        

 } 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring MVC拦截器是一种应用于请求和响应过程中的过滤器,可以用于对请求进行预处理、对响应进行后处理,以及在请求到达处理程序之前或处理程序返回响应之后执行某些操作。 在Spring MVC中,拦截器是通过实现HandlerInterceptor接口来实现的。该接口定义了三个方法,分别是preHandle()、postHandle()和afterCompletion()。 - preHandle()方法在请求到达处理程序之前执行,可以用于进行身份验证、权限校验等操作,如果该方法返回false,则请求将被拦截并不会到达处理程序。 - postHandle()方法在处理程序完成请求处理后但尚未返回响应时执行,可以用于修改响应或添加一些额外的信息。 - afterCompletion()方法在请求处理完成后执行,无论成功或失败都会执行,可以用于进行资源清理等操作。 要使用拦截器,需要在Spring配置文件中进行配置,并将其注册到DispatcherServlet中。 下面是一个简单的拦截器示例,用于记录请求处理时间: ```java public class TimeInterceptor implements HandlerInterceptor { private static final Logger LOGGER = LoggerFactory.getLogger(TimeInterceptor.class); @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { request.setAttribute("startTime", System.currentTimeMillis()); return true; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { long startTime = (long) request.getAttribute("startTime"); long endTime = System.currentTimeMillis(); LOGGER.info("Request URL: {} , Time: {}ms", request.getRequestURL(), endTime - startTime); } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { // do nothing } } ``` 在Spring配置文件中进行配置: ```xml <mvc:interceptors> <bean class="com.example.TimeInterceptor" /> </mvc:interceptors> ``` 这样,每次请求处理完成后,日志中就会打印该请求的处理时间,以便进行性能优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值