欢迎讨论:spring boot入门【7】拦截器Interceptor实现原理【转】!

-发帖者:
-参与讨论....
【主题】:spring boot入门【7】拦截器Interceptor实现原理【转】

很多同学搞不懂拦截器和过滤器的区别,我们先说一下他们的区别:

过滤器和拦截器非常相似,但是它们有很大的区别
最简单明了的区别就是过滤器可以修改request,而拦截器不能
过滤器需要在servlet容器中实现,拦截器可以适用于javaEE,javaSE等各种环境
拦截器可以调用IOC容器中的各种依赖,而过滤器不能
过滤器只能在请求的前后使用,而拦截器可以详细到每个方法
通俗的说过滤器就是筛选出你要的东西,比如requeset中你要的那部分
拦截器在做安全方面用的比较多,比如终止一些流程。

接下来我们举个简单的例子:

1、建立interceptor包,在此包下建立Interceptor类。此处我们以处理Ajax跨域请求为例,关于跨域请求,大家不懂的可以自行学习。代码如下
 

public class Interceptor implements HandlerInterceptor {
    
    public void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3)
            throws Exception {
        // TODO Auto-generated method stub
    }
 
    public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3)
            throws Exception {
        // TODO Auto-generated method stub
    }
 
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object arg2) throws Exception {
 
        response.setHeader("Access-Control-Allow-Origin", request.getHeader("Origin"));
        response.setHeader("Access-Control-Allow-Methods", "*");
        response.setHeader("Access-Control-Allow-Credentials", "true");
        response.setHeader("Access-Control-Allow-Headers", "x-requested-with,content-type");
        System.err.println("------------------>:已完成跨域处理");
        return true;
    }
}

注意此类实现了HandlerInterceptor接口。

2、我们还要注册一下此拦截器才能被springboot检测到,在config包下建立AppConfigurer类,代码如下:

@Configuration
public class MvcConfig implements WebMvcConfigurer {
 
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
 
        registry.addInterceptor(new Interceptor()).addPathPatterns("/**");
    }
}

注意此类实现了了WebMvcConfigurer接口。addInterceptors方法为拦截器实例注册方法。当然,“new interceptor()”也可以写成自动装配的方式。

3、测试结果如下:

拦截器适配成功

 发表评论     发表时间:『2020-06-10 16:06:10』


扫描二维码关注网站最新动态