SpringBoot 拦截器 | 过滤器 | 监听器css
1.拦截器:拦截器,在AOP(Aspect-Oriented Programming)中用于在某个方法或字段被访问以前,进行拦截而后在以前或以后加入某些操做。拦截是AOP的一种实现策略。通常用于拦截用户登陆,用户验证等。java
2.过滤器:它能够对客户的请求进行处理。处理完成后,它会交给下一个过滤器处理,这样,客户的请求在过滤链里逐个处理,直到请求发送到目标为止。通常用于对数据的处理。web
3.监听器:能够用于监听Web应用中某些对象,信息的建立,销毁,增长,修改,删除等动做的发生,而后作出相应的响应处理spring
1.配置拦截器:session
实现的 HandlerInterceptor 接口jsp
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中添加拦截器:ide
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样式 } }
拦截器配置完成!post
2.过滤器配置url
建立test1过滤器类:spa
//拦截请求 //@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); } }
过滤器配置完完成!