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

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); } }

 过滤器配置完完成!

相关文章
相关标签/搜索