springboot 拦截器执行两次的解决方案
springboot拦截器执行两次
原因是:
org.springframework.boot.autoconfigure.web.servlet.error.BasicErrorController.error
也是一个controller路径为/error
@Configuration public class MVCConfig extends WebMvcConfigurationSupport { //自定义的拦截器 @Bean public SecurityInterceptor getSecurityInterceptor() { return new SecurityInterceptor(); } @Override public void addInterceptors(InterceptorRegistry registry) { //添加拦截器 InterceptorRegistration registration = registry.addInterceptor(getSecurityInterceptor()); //排除的路径 registration.excludePathPatterns("/login"); registration.excludePathPatterns("/logout"); //将这个controller放行 registration.excludePathPatterns("/error"); //拦截全部 registration.addPathPatterns("/**"); } }
Springboot拦截器原理
根据当前请求,找到**HandlerExecutionChain**** 【可以处理请求的handler以及handler的所有 拦截器】
先来顺序执行 所有拦截器的 preHandle方法
如果当前拦截器prehandler返回为true。则执行下一个拦截器的preHandle
如果当前拦截器返回为false。直接 倒序执行所有已经执行了的拦截器的 afterCompletion;
如果任何一个拦截器返回false。直接跳出不执行目标方法
所有拦截器都返回True。执行目标方法
倒序执行所有拦截器的postHandle方法。
前面的步骤有任何异常都会直接倒序触发 afterCompletion
页面成功渲染完成以后,也会倒序触发 afterCompletion
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Java并发编程深入理解之Synchronized的使用及底层原理详解 下
在并发编程中存在线程安全问题,主要原因有:1.存在共享数据 2.多线程共同操作共享数据。关键字synchronized可以保证在同一时刻,只有一个线程可以执行某个方法或某个代码块,同时synchronized可以保证一个线程的变化可见(可见性),即可以代替volatile2021-09-09Java 类型相互转换byte[]类型,Blob类型详细介绍
这篇文章主要介绍了Java 类型相互转换byte[]类型,Blob类型的相关资料,需要的朋友可以参考下2016-10-10Spring ApplicationContext接口功能详细介绍
ApplicationContext是Spring应用程序中的中央接口,由于继承了多个组件,使得ApplicationContext拥有了许多Spring的核心功能,如获取bean组件,注册监听事件,加载资源文件等2023-02-02
最新评论