SpringBoot 拦截器/过滤器/监听器

SpringBoot 拦截器 | 过滤器 | 监听器

1.拦截器:拦截器,在AOP(Aspect-Oriented Programming)中用于在某个方法或字段被访问之前,进行拦截然后在之前或之后加入某些操作。拦截是AOP的一种实现策略。一般用于拦截用户登录,用户验证等。

2.过滤器:它可以对客户的请求进行处理。处理完成后,它会交给下一个过滤器处理,这样,客户的请求在过滤链里逐个处理,直到请求发送到目标为止。一般用于对数据的处理。

3.监听器:可以用于监听Web应用中某些对象,信息的创建,销毁,增加,修改,删除等动作的发生,然后做出相应的响应处理

 

1.配置拦截器:

实现的 HandlerInterceptor 接口

package com.intercept;

import org.springframework.lang.Nullable;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class UserInterceptor implements HandlerInterceptor {
    //方法执行前
    @Override
    public boolean preHandle(HttpServletRequest req, HttpServletResponse resp, Object o) throws Exception {
        System.out.println("方法执行前");
        if(req.getSession().getAttribute("user")==null){
            System.out.println("用户未登录或session失效");
            resp.sendRedirect("/login/to_login");
            return false;
        }
        return true;
    }
    //方法执行后
    @Override
    public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception {
        System.out.println("方法执行后");
    }
    //页面渲染前
    @Override
    public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception {
        System.out.println("页面渲染前");
    }
}
  • preHandle:在调用Controller方法前会调用此方法
  • postHandle:在调用Controller方法后调用此方法后,页面渲染之前调用此方法,比如可以在这里将渲染的视图名称更改为其他视图名称。
  • afterCompletion:页面渲染完毕后调用此方法,通常用来清除某些资源,类似Java语法的finally


在WebMvcConfigurer中添加拦截器:

package com.intercept;

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 {
    //添加拦截器
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(new UserInterceptor())
               .addPathPatterns("/**")     //拦截请求
               .excludePathPatterns("/login/to_login","/login/do_login",
                       "/**/*.css","/**/*.js", "/**/*.png", "/**/*.jpg",
                        "/**/*.jpeg", "/**/*.gif", "/**/fonts/*"); //不拦截登录,和HTML样式
    }
}

 

拦截器配置完成!

2.过滤器配置

创建test1过滤器类:

//拦截请求
//@WebFilter(filterName = "test1",urlPatterns = {"*.do","*.jsp"})
@WebFilter(filterName = "test1",urlPatterns = "/test1")
public class test1 implements Filter {
    public void destroy() {
    }
    public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException {
        System.out.println("进入filter");
        //放行
        chain.doFilter(req,resp);
        System.out.println("离开filter");
    }
    public void init(FilterConfig config) throws ServletException {
    }
}

在启动类加上注解 @ServletComponentScan

@SpringBootApplication
@ServletComponentScan  //在spring boot启动时会扫描@WebServlet,并将该类实例化
public class App {
    public static void main(String[] args) {
        SpringApplication.run(App.class,args);
    }
}

 过滤器配置完完成!

posted @ 2019-05-29 19:16  Cool_Yang  阅读(558)  评论(0编辑  收藏  举报