zoukankan      html  css  js  c++  java
  • 前后端分离,SpringBoot拦截器中,获取的请求头token为NULL问题解决

    背景:

    在做前后端分离时,牵扯到跨域,但是已经设置了跨域
    前端设置了允许携带Cookie
    axios.defaults.withCredentials = true;
    后端也配置了跨域:

    @Configuration
    public class WebConfig implements WebMvcConfigurer {
        @Override
        public void addCorsMappings(CorsRegistry registry) {
            //项目中的所有接口都支持跨域
            registry.addMapping("/**")
                    //所有地址都可以访问,也可以配置具体地址
                    .allowedOrigins("*")
                    //允许的请求方式
                    .allowedMethods("POST", "GET", "PUT", "OPTIONS", "DELETE")
                    //是否支持跨域Cookie
                    .allowCredentials(true)
                    // 跨域允许时间
                    .maxAge(3600);
        }
    }

    浏览器端查看发送的请求,请求头中包含Authorization

     但是在后端拦截器中获取的参数总是为null

     

    原因:
    实际上发送了两次请求,第一次为OPTIONS请求,第二次才GET/POST...请求
    在OPTIONS请求中,不会携带请求头的参数,所以在拦截器上获取请求头为空,自定义的拦截器拦截成功
    第一次请求不能通过,就不能获取第二次的请求了GET/POST...
    第一次请求不带参数,第二次请求才带参数

    解决:

    在拦截器中,如果请求为OPTIONS请求,则返回true,表示可以正常访问,然后就会收到真正的GET/POST请求

    if (HttpMethod.OPTIONS.toString().equals(request.getMethod())) {
        System.out.println("OPTIONS请求,放行");
        return true;
    }
  • 相关阅读:
    大文件上传实现总结
    JDK线程池异常处理方式
    packageinfo.java 作用
    VBA 发送邮件代码
    TCP/IP协议、DoD模型、OSI模型
    3D空间基础概念之三:几何变换
    IP寻址
    IP地址排错命令
    WIN7用户文件夹迁移
    IP报头包含的协议
  • 原文地址:https://www.cnblogs.com/lyh233/p/14472245.html
Copyright © 2011-2022 走看看