Springboot2.0自定义拦截器

 在JavaEE中,经常用filter来做拦截器,后来有了SpringMvc,我们使用HandlerInterceptor进行拦截,现在有了Springboot,我们也使用HandlerInterceptor进行拦截,但我们不用xml的配置了,省去很多的事情。

 1、自定义拦截器

public class TestInterceptor implements HandlerInterceptor {
    /**
     * 目标方法执行之前执行
     *
     * @param request
     * @param response
     * @param handler
     * @return
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {
        if (true) {
            System.out.println("该请求已被拦截......");
            return false;
        }
        return true;
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) {

    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) {

    }
}

如果拦截成功,控制台会打印:该请求已被拦截......

 2、配置拦截器
 在springmvc中,使用xml进行配置,但在springboot中,这里使用java配置,具体如下:

/**
 * 使用WebMvcConfigurer可以来扩展SpringMVC的功能
 * 
 * 在spring5.0之前可以继承WebMvcConfigurerAdapter此适配器进行配置,但spring5.0以后此适配器就被废弃(已被标注为@Deprecated),
 * 目前有两种解决方案,一种是直接实现WebMvcConfigurer,另一种是直接继承WebMvcConfigurationSupport,官方推荐第一种方案。
 */
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {

    /**
     * 自定义拦截规则
     *
     * @param registry
     */
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        // addPathPatterns - 用于添加拦截规则
        // excludePathPatterns - 用户排除拦截
        registry.addInterceptor(new TestInterceptor())
                .addPathPatterns("/**")
                .excludePathPatterns("/index.html", "/", "/user/login");
    }
}

上面自定义的拦截规则,首先我们使用 addPathPatterns("/**"); 添加对所有请求都拦截;然后在使用excludePathPatterns("/index.html", "/", "/user/login"); 将index.html和/user/login两个url设置不拦截。

3、Controller测试

@RestController
public class TestController {

    @RequestMapping("/user/login")
    public String hello() {
        return "User Login!";
    }

    @RequestMapping("/hello")
    public String world() {
        return "Hello World!";
    }
}

测试结果如下:

在浏览器输入:http://localhost:8088/user/login,该链接不会被拦截,在页面输出:User Login!
在浏览器输入:http://localhost:8088/,该请求会被拦截,控制台会打印出:该请求已被拦截......

你可能感兴趣的:(Springboot2.0自定义拦截器)