TypechoJoeTheme

香草物语

统计
登录
用户名
密码
/
注册
用户名
邮箱
输入密码
确认密码

Spring Boot注册拦截器Interceptor

Laughing博主
2021-06-07
/
1 评论
/
1,090 阅读
/
379 个字
/
百度已收录
06/07
本文最后更新于2024年03月17日,已超过187天没有更新。如果文章内容或图片资源失效,请留言反馈,我会及时处理,谢谢!

Spring MVC提供了AOP风格的拦截器,拥有更加精细的拦截器处理能力。Spring Boot中拦截器的注册更加方便,步骤如下:

  1. spring-boot-starter-web
  2. 创建拦截器,实现HandlerInterceptor
  3. 配置拦截器,定义配置类进行拦截器的配置

增加依赖

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>

实现HandlerInterceptor

代码如下:

public class MyInterceptor implements HandlerInterceptor {

    private final Logger logger = LoggerFactory.getLogger(MyInterceptor.class);

    /**
     * 方法执行前运行
     * 必须返回true,后面的方法才能执行
     * @param request
     * @param response
     * @param handler
     * @return
     * @throws Exception
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        logger.info("我先执行");
        return true;
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        logger.info("我在controller方法之后执行");
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        logger.info("我最后执行");
    }
}

配置拦截器

@Configuration
public class MyWebMvcConfig implements WebMvcConfigurer {

    /**
     * 拦截器
     *
     * @param registry registry
     */
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(new MyInterceptor())
                //配置拦截的路由
                .addPathPatterns("/interceptor/**")
                //配置不拦截的路由
                .excludePathPatterns("/demo/**")
                //配置顺序
                .order(1);
    }
}

测试

定义controller测试我们的拦截器

@RestController
@RequestMapping("interceptor")
public class InterceptorController {

    private final Logger logger = LoggerFactory.getLogger(InterceptorController.class);

    @GetMapping("/test")
    public String testInterceptor(){
        logger.info("我是controller方法");
        return "success";
    }
}

通过调用http://localhost:8080/interceptor/test查看输出日志。

温馨提示
  • 拦截器按照preHandle→Controller→postHandle→afterHandle的顺序执行。
  • 只有preHandle方法返回true时,后面的方法才会执行。
  • 当拦截器链内存在多个拦截器时,postHandle在拦截器链内所有拦截器返回成功时才会调用。
  • 当拦截器链内存在多个拦截器时,afterHandle在拦截器链内所有拦截器返回true时才会调用。
  • 当拦截器链内存在多个拦截器时,如果第一个拦截器的preHandle方法返回false,则后面的方法都不会执行。
  • 调用controller方法时,只要配置了拦截的路由,哪怕前端请求404,仍然会调用preHandle、postHandle及afterHandle的方法。

如果我们设置了order,代码如下:

/**
     * 拦截器
     *
     * @param registry registry
     */
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(new MyInterceptor2())
                //配置拦截的路由
                .addPathPatterns("/interceptor/**")
                //配置不拦截的路由
                .excludePathPatterns("/demo/**")
                //配置顺序
                .order(200);
        registry.addInterceptor(new MyInterceptor1())
                //配置拦截的路由
                .addPathPatterns("/interceptor/**")
                //配置不拦截的路由
                .excludePathPatterns("/demo/**")
                //配置顺序
                .order(300);
    }
拦截器Spring Boot
朗读
赞(1)
赞赏
感谢您的支持,我会继续努力哒!
版权属于:

香草物语

本文链接:

https://www.xiangcaowuyu.net/java/spring-boot-register-interceptor.html(转载时请注明本文出处及文章链接)

评论 (1)
  1. 23424 闲逛
    Windows 10 · Google Chrome

    {!{}!}

    2021-06-08 回复
  2. 穆伊扎 闲逛
    iPhone · Safari

    不错,学习了

    2017-06-14 回复