springboot之拦截器
本篇文章就来讲讲拦截器,springboot中拦截器的注册还是比较方便的。大概下面两个步骤:
1.实现HandlerInterceptor接口创建拦截器
2.实现WebMvcConfigurer接口配置拦截器
下面使用一个简单的例子,来大概展示一下具体使用:
场景:两个页面,登录页面可以随便访问,但是首页只有xiongda用户输入正确密码才能访问
第一步,创建拦截器
public class MyInterceptor implements HandlerInterceptor{ @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { System.out.println("==========jin ru pre handle ===="); String username = request.getParameter("username"); String password = request.getParameter("password"); System.out.println(username +","+password); if("xiongda".equals(username) && "123456".equals(password)) { return true; }else { return false; } } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { System.out.println("================= jin ru after ==============="); } }
第二步,配置拦截器
@Configuration public class WebMvcConfig implements WebMvcConfigurer{ @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(new MyInterceptor()) .addPathPatterns("/**") .excludePathPatterns("/static/login.html"); } }
接下来根据具体结果来讲解:
上面两张图是访问登录页面,登录页面在拦截器配置中配置的是排除路径,可以看到即使放开了,还是会进入prehandle,但是不会执行任何操作
进入首页的时候,会在prehandle中进行判断,只有为true的时候才会执行后面的afterCompletion方法
注意点:
1.拦截器中方法的执行顺序是 preHandle -> Controller -> postHandle -> afterCompletion
只有preHandle返回true,才会执行后面的方法
务实,说实话!