springboot拦截器

springboot拦截器

拦截器

基于Java反射机制,不依赖与servlet容器,只能对action请求起作用,可以访问action上下文、值栈里的对象,在action的生命周期中可以多次被调用,可以获取IOC容器中的各个bean

过滤器

基于函数回调,依赖与servlet容器,可以对几乎所有的请求起作用,不能访问action上下文、值栈里的对象,只能在容器初始化时被调用一次,不能获取IOC容器中的各个bean。

springboot中实现拦截器比较简单:

1.创建我们自己的拦截器类并实现 HandlerInterceptor 接口

public class MyInterCeptor implements HandlerInterceptor{

    @Override
    public boolean preHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o) throws Exception {
        System.out.println("在请求处理之前进行调用(Controller方法调用之前)");
        return true;// 只有返回true才会继续向下执行,返回false取消当前请求
    }

    @Override
    public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception {
        System.out.println("请求处理之后进行调用,但是在视图被渲染之前(Controller方法调用之后)");
    }

    @Override
    public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception {
        System.out.println("在整个请求结束之后被调用,也就是在DispatcherServlet 渲染了对应的视图之后执行(主要是用于进行资源清理工作)");
    }
}

 

2.创建一个Java类继承WebMvcConfigurerAdapter,并重写 addInterceptors 方法。

3.实例化我们自定义的拦截器,然后将对像手动添加到拦截器链中(在addInterceptors方法中添加)。

@Configuration
public class MyWebAppConfigurer extends WebMvcConfigurerAdapter {
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        // 多个拦截器组成一个拦截器链,addPathPatterns 用于添加拦截规则,excludePathPatterns 用户排除拦截
        registry.addInterceptor(new MyInterCeptor1()).addPathPatterns("/**");
        registry.addInterceptor(new MyInterCeptor2()).addPathPatterns("/**");
    }
}

执行之后的顺序:

2017-01-17 17:28:15.683  INFO 6460 --- [nio-8088-exec-1] o.s.web.servlet.DispatcherServlet        : FrameworkServlet 'dispatcherServlet': initialization started
2017-01-17 17:28:15.697  INFO 6460 --- [nio-8088-exec-1] o.s.web.servlet.DispatcherServlet        : FrameworkServlet 'dispatcherServlet': initialization completed in 14 ms
MyFilter2执行
MyFilter1执行
MyFilter3执行
11111在请求处理之前进行调用(Controller方法调用之前)
22222在请求处理之前进行调用(Controller方法调用之前)
Session 被创建
22222请求处理之后进行调用,但是在视图被渲染之前(Controller方法调用之后)
11111请求处理之后进行调用,但是在视图被渲染之前(Controller方法调用之后)
22222在整个请求结束之后被调用,也就是在DispatcherServlet 渲染了对应的视图之后执行(主要是用于进行资源清理工作)
11111在整个请求结束之后被调用,也就是在DispatcherServlet 渲染了对应的视图之后执行(主要是用于进行资源清理工作)

根据输出可以了解拦截器链的执行顺序。

只有经过DispatcherServlet 的请求,才会走拦截器链,我们自定义的Servlet 请求是不会被拦截的,比如我们自定义的Servlet地址 http://localhost:8088/servlet1/1是不会被拦截器拦截的。并且不管是属于哪个Servlet 只要符合过滤器的过滤规则,过滤器都会拦截。

转载于:https://my.oschina.net/zk875/blog/826641

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值