springboot2.x自定义拦截把static静态文件给拦截的坑

Posted 今天不打怪

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了springboot2.x自定义拦截把static静态文件给拦截的坑相关的知识,希望对你有一定的参考价值。

新人新帖,喷后请指正,谢谢

1.王中王,坑中坑

  和很多人一样,我在springboo自定义配置登录拦截的时候,写一个WebConfig类继承WebMvcConfigureAdapter,重写AddResourceHandlers,然后乐呵呵的去实现HandlerInterceptor,在preHandle里写逻辑,然后访问登录页面,然后what a fuck,我登录页面的样式呢?怎么就几个框框了?满脸黑人问号?

  项目目录:

  

  properties配置的静态路径:spring.mvc.static-path-pattern=/resources/**

  WebConfig里的静态文件配置和拦截配置如下:

    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        // 配置模板资源路径
         registry.addResourceHandler("/templates/**").addResourceLocations(ResourceUtils.CLASSPATH_URL_PREFIX+"/templates/");  
        registry.addResourceHandler("/static/**").addResourceLocations(ResourceUtils.CLASSPATH_URL_PREFIX+"/static/");  
    }
    
    
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
//        InterceptorRegistration addInterceptor = registry.addInterceptor(getSecurityInterceptor());
        // 不可以下面方式操作,如果那样写是不可以的。这样等于是创建了多个Interceptor。而不是只有一个Interceptor 
//        addInterceptor.excludePathPatterns("/login");
//        addInterceptor.excludePathPatterns("/login/main");
//        //拦截所有路径
//       addInterceptor.addPathPatterns("/**");
        // addPathPatterns("/**")对所有请求都拦截,但是排除了/login/main和/login请求的拦截
        registry.addInterceptor(getSecurityInterceptor())
            .addPathPatterns("/**")
            .excludePathPatterns("/login","/login/main");
    }
    
    @Bean
    public MyInterceptor getSecurityInterceptor() {
        return new MyInterceptor();
    }

  

/**
     * 在controller之前执行
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
            throws Exception {
       log.info("开始检测是否登录");
       log.info(request.getRequestURL().toString());
       // 判断是否已有该用户登录的session
       if (request.getSession().getAttribute(SESSION_KEY) != null) {
           log.info("用户已登录");
           return true;
       }
       log.info("用户尚未登录");
       // 跳转到登录页
       response.sendRedirect(request.getContextPath() + "/login");
       return false;
    }
    

    @Override
    public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception {

    }

    @Override
    public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception {

    }

  打印请求地址输出后发现(log.info(request.getRequestURL().toString())),static下的静态页面都被拦截了,一脸懵逼加问号中。

2.解决办法

  网上查了一大堆资料,都没有说到点子上的,之道后来发现原因竟然是:版本居然是:

  spring boot 2.x已经改为最低支持jdk8版本,而jdk8中的接口允许有默认实现,所以已经废弃掉WebMvcConfigurerAdapter适配类,而改为直接实现WebMvcConfigurer接口。

  以上信息来自==>https://my.oschina.net/dengfuwei/blog/1795346的帮助。

  然后 WebConfig implements WebMvcConfigurer,是要实现啊WebMvcConfigurer。。。。。。然后修改一下拦截,注解只留@Configuration。

registry.addInterceptor(getSecurityInterceptor())
            .addPathPatterns("/**")
            .excludePathPatterns("/login","/login/main","/static/**");

 

   重启项目,访问:http://localhost:8080/login,完美

  

以上是关于springboot2.x自定义拦截把static静态文件给拦截的坑的主要内容,如果未能解决你的问题,请参考以下文章

SpringBoot2.X新版本配置拦截器在项目中的使用

springboot2.x里面访问静态资源的坑

SpringBoot2.x之WebMvcConfigurer

SpringBoot2.x整合Redis缓存自定义序列化

SpringBoot2.x系列教程(七十)Spring Boot Actuator集成及自定义Endpoint详解

springboot2.x+MyBatis-Plus+mysql5.7 动态拼接sql语句 分页查询 自定义sql 查询条件 分组 排序