从原理带你掌握Spring MVC拦截处理器知识

2021年11月21日 阅读数:15
这篇文章主要向大家介绍从原理带你掌握Spring MVC拦截处理器知识,主要内容包括基础应用、实用技巧、原理机制等方面,希望对大家有所帮助。
摘要:SpringWebMVC的处理器拦截器,相似于Servlet开发中的过滤器Filter,用于处理器进行预处理和后处理。

本文分享自华为云社区《不讲废话,全程干货,0基础带你学习SpringMVC拦截处理器》,做者:JavaEdge 。web

1 工做原理流程图

2 Spring Web MVC 的处理器拦截器

  • HandlerInterceptor

相似Servlet 开发中的过滤器Filter,用于对处理器进行预处理和后处理。spring

HandlerInterceptor接口定义了以下方法:session

2.1 preHandle

该方法将在请求处理以前进行调用,只有当该方法返回true时,才会继续调用下一个Interceptor的preHandle(),若是已经是最后一个Interceptor就会是调用当前请求的Controllermvc

2.2 postHandle

该方法将在请求处理后,DispatcherServlet进行视图返回渲染以前进行调用,能够在这个方法中对Controller处理以后的ModelAndView对象进行操做(好比这里加入公用信息以便页面显示)app

2.3 afterCompletion

该方法也是须要当前对应的Interceptor的preHandle方法的返回值为true时才会执行,该方法将在整个请求结束以后,也就是在DispatcherServlet 渲染了对应的视图以后执行,用于资源清理。jsp

3 拦截器配置

3.1 针对某种mapping拦截器配置

 <bean  
   class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping">  
   <property name="interceptors">  
      <list>  
         <ref bean="handlerInterceptor1"/>  
         <ref bean="handlerInterceptor2"/>  
      </list>  
   </property>  
</bean>  
<bean id="handlerInterceptor1"class="springmvc.intercapter.HandlerInterceptor1"/>  
<bean id="handlerInterceptor2"class="springmvc.intercapter.HandlerInterceptor2"/> 

3.2 针对全部mapping配置全局拦截器

<!--拦截器 -->  
<mvc:interceptors>  
   <!--多个拦截器,顺序执行 -->  
   <mvc:interceptor>  
      <mvc:mapping path="/**"/>  
      <bean class="com.sss.filter.HandlerInterceptor1"></bean>  
   </mvc:interceptor>  
   <mvc:interceptor>  
      <mvc:mapping path="/**"/>  
      <bean class="com.sss.filter.HandlerInterceptor2"></bean>  
   </mvc:interceptor>  
</mvc:interceptors>  

4 实践

用户访问其余页面时,从Seesion中获取到用户,未登陆则重定向到登陆页面。ide

Public class LoginInterceptor implements HandlerInterceptor{   
    @Override  
    Public boolean preHandle(HttpServletRequest request,  
            HttpServletResponse response, Object handler) throws Exception {  
 
        //若是是登陆页面则放行  
        if(request.getRequestURI().indexOf("login.action")>=0){  
            return true;  
        }  
        HttpSession session = request.getSession();  
        //若是用户已登陆也放行  
        if(session.getAttribute("user")!=null){  
            return true;  
        }  
        //用户没有登陆挑战到登陆页面  
        request.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(request, response);  
 
        return false;  
    }  

 

点击关注,第一时间了解华为云新鲜技术~post