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); } }
过滤器配置完完成!