一.什么是拦截器

类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理。
依赖于web框架,在实现上基于Java的反射机制,属于面向切面编程(AOP)的一种运用。由于拦截器是基于web框架的调用,因此可以使用Spring的依赖注入(DI)进行一些业务操作,同时一个拦截器实例在一个controller生命周期之内可以多次调用。

二.拦截器常应用的场景

1)日志记录:记录请求信息的日志,以便进行信息监控、信息统计、计算PV(Page View)等。
2)权限检查:如登录检测,进入处理器检测是否登录,如果没有直接返回到登录页面;
3)性能监控:有时候系统在某段时间莫名其妙的慢,可以通过拦截器在进入处理器之前记录开始时间,在处理完后记录结束时间,从而得到该请求的处理时间(如果有反向代理,如apache可以自动记录);
4)通用行为:读取cookie得到用户信息并将用户对象放入请求,从而方便后续流程使用,还有如提取Locale、Theme信息等,只要是多个Controller中的处理方法都需要的,我们就可以使用拦截器实现。
5)OpenSessionInView:如Hibernate,在进入处理器打开Session,在完成后关闭Session。

三.如何实现

3)在SpringMVC中实现拦截器需要实现 HandlerInterceptor,其中包含三个需要的方法:preHandle()、postHandle()、afterCompletion()。
preHandle(): 在Controller method 之前执行,通常用于做参数校验、登录验证等。
postHandle(): 在Controller method 之后执行,需要注意的是,当Controller中发生异常时,并不会执行postHandle,而是跳过后执行afterCompletion 方法。
afterCompletion(): 在postHandle执行之后执行,发生异常也会执行,通常用于释放系统资源。

1)实现接口HandlerInterceptor

springboot 指定路径请求转发 拦截器 springboot定义拦截器_spring

2)继承类HandlerInterceptorAdapter

springboot 指定路径请求转发 拦截器 springboot定义拦截器_java_02


开始编码

springboot 指定路径请求转发 拦截器 springboot定义拦截器_程序人生_03

首先写个配置类继承WebMvcConfigurationSupport重写添加拦截器的方法,添加@Configuration注解申明配置类,创建你需要添加的自定义拦截器的对象添加进去。
addPathPatterns("/**").excludePathPatterns("/login");
表示拦截所有的路径但排除/login。

package com.yu.config;

import com.yu.interceptor.UserInterceptor;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurationSupport;

@Configuration
public class WebMvcConfig extends WebMvcConfigurationSupport {
    @Override
    protected void addInterceptors(InterceptorRegistry registry) {
        super.addInterceptors(registry);
        registry.addInterceptor(new UserInterceptor()).addPathPatterns("/**").excludePathPatterns("/login");
    }
}

Controller层

package com.yu.controller;

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class UserController {
    @RequestMapping("/")
    public void test(){
        System.out.println("hello");
    }
    @RequestMapping("/login")
    public void login(){
        System.out.println("login");
    }
    @RequestMapping("/exit")
    public void exit(){
        System.out.println("退出");
    }
}

springboot 指定路径请求转发 拦截器 springboot定义拦截器_java_04

看log就一目了然。。。。
其实配置类相当于配置文件所以不写配置文件也可以通过添加spring-mvc.xml配置文件使用mvc:interceptor来实现以上而达到效果。