• springboot 拦截器


    拦截器的实现:

    创建自定义拦截器CustomInterceptor:

    package com.xc.boot.handler;
    import org.springframework.stereotype.Component;
    import org.springframework.web.servlet.HandlerInterceptor;
    import org.springframework.web.servlet.ModelAndView;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    
    @Component
    public class CustomInterceptor implements HandlerInterceptor {
        /**
         * 预处理回调方法,实现处理器的预处理(如登录检查),第三个参数为响应的处理器;
         * 返回值:true表示继续流程(如调用下一个拦截器或处理器);
         * false表示流程中断(如登录检查失败),不会继续调用其他的拦截器或处理器,此时我们需要通过response来产生响应;
         */
        @Override
        public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
            System.out.println("===========CustomInterceptor preHandle");
            return true;
        }
    
        /**
         * 整个请求处理完毕回调方法,即在视图渲染完毕时回调,如性能监控中我们可以在此记录结束时间并输出消耗时间,
         * 还可以进行一些资源清理,类似于try-catch-finally中的finally
         */
        @Override
        public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
            System.out.println("===========CustomInterceptor postHandle");
        }
    
        /**
         * 后处理回调方法,实现处理器的后处理(但在渲染视图之前),此时我们可以通过modelAndView(模型和视图对象)对模型数据进行处理或对视图进行处理
         */
        @Override
        public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
            System.out.println("===========CustomInterceptor afterCompletion");
        }
    }

    创建配置类InterceptorConfig:

    package com.xc.boot.config.control;
    import com.xc.boot.handler.CustomInterceptor;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
    import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
    
    @Configuration
    public class InterceptorConfig implements WebMvcConfigurer {
        @Autowired
        private CustomInterceptor customInterceptor;
    
        @Override
        public void addInterceptors(InterceptorRegistry registry) {
            registry.addInterceptor(customInterceptor).addPathPatterns("/**");
        }
    }

    多个拦截器同时工作流程图:

    拦截器与过滤器的区别:

    触发时机:

      过滤器是JavaEE标准,采用函数回调的方式进行。是在请求进入容器之后,还未进入Servlet之前进行预处理,并且在请求结束返回给前端这之间进行后期处理。

      过滤器的触发时机是容器后,servlet之前,所以过滤器的doFilter(ServletRequest request, ServletResponse response, FilterChain chain)的入参是ServletRequest ,而不是httpservletrequest。因为过滤器是在httpservlet之前。

      调用Servlet的doService()方法是在chain.doFilter(request, response)这个方法中进行的。

      过滤器包裹住servlet,servlet包裹住拦截器。

      a.preHandle()这个方法是在过滤器的chain.doFilter(request, response)方法的前一步执行,也就是在 [System.out.println("before...")][chain.doFilter(request, response)]之间执行。

      b.preHandle()方法之后,在return ModelAndView之前进行,可以操控Controller的ModelAndView内容。

      c.afterCompletion()方法是在过滤器返回给前端前一步执行,也就是在[chain.doFilter(request, response)][System.out.println("after...")]之间执行。

    注:

    SpringMVC的机制是由同一个Servlet来分发请求给不同的Controller,其实这一步是在Servlet的service()方法中执行的

    还有,拦截器是spring容器的,是spring支持的

     总结:拦截器功在对请求权限鉴定方面确实很有用处,第三方的远程调用每个请求都需要参与鉴定,所以这样做非常方便,而且是很独立的逻辑,这样做让业务逻辑代码很干净。

    参考文章:

    https://www.cnblogs.com/panxuejun/p/7715917.html

  • 相关阅读:
    13 内建属性 _getattribute_ 内建函数
    12 垃圾回收GC
    11 元类
    12 动态语言 __slots__
    11 作用域
    10 带参数的装饰器 通用装饰器 类装饰器
    9 装饰器
    8 闭包
    6 生成器 yield 协程
    cmd常用命令
  • 原文地址:https://www.cnblogs.com/ooo0/p/10331705.html
Copyright © 2020-2023  润新知