Vue 使用 axios 发起 HTTP 请求未携带 Cookie 的原因

本文将介绍当 Vue 使用 axios 发起请求时,请求没有携带 cookie 信息的几个原因。

当 Vue 使用 axios 发起请求时,如果请求没有携带 cookie 信息,可能是由于以下几个原因导致。

原因一:跨域请求

如果请求的目标服务器与当前页面的域名不同,浏览器默认不会发送 cookie。解决此问题可以在请求头中设置 withCredentials: true,表示允许发送 cookie。例如:

axios.get('http://example.com/api/data', {
  withCredentials: true
});

原因二:服务器未设置 Access-Control-Allow-Credentials 响应头

如果目标服务器未设置 Access-Control-Allow-Credentials: true 响应头,浏览器也不会发送 cookie。需要确保服务器设置了该响应头。

Node.js 示例

在 Node.js 中使用 Express 框架设置,如:

app.use(function(req, res, next) {
  res.header('Access-Control-Allow-Origin', 'http://example.com');
  res.header('Access-Control-Allow-Credentials', true);
  next();
});

Java示例

httpResponse.setHeader("Access-Control-Allow-Origin", "http://example.com");
// 如果要把Cookie发到服务器,需要指定 Access-Control-Allow-Credentials 字段为 true
httpResponse.setHeader("Access-Control-Allow-Credentials", "true");

Nginx示例

location / { 
  add_header Access-Control-Allow-Origin http://example.com;
  add_header Access-Control-Allow-Credentials true;
  add_header Access-Control-Allow-Methods 'GET, POST, OPTIONS';
  add_header Access-Control-Allow-Headers 'DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Authorization';
}

Spring Boot示例

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

@Configuration
public class CorsConfig {
    @Bean
    public WebMvcConfigurer corsConfigurer() {
        return new WebMvcConfigurer() {
            @Override
            public void addCorsMappings(CorsRegistry registry) {
                // 添加映射路径
                registry.addMapping("/**")
                        .allowedOriginPatterns("http://example.com")   // 放行哪些域名,可以多个
                        .allowCredentials(true)       // 是否发送Cookie信息
                        .allowedMethods("GET", "HEAD", "POST", "PUT", "DELETE", "OPTIONS", "PATCH") // 放行哪些请求方式
                        .allowedHeaders("*")          // 放行哪些原始域(头部信息)
                        .exposedHeaders("Header1", "Header2") // 暴露哪些头部信息(因为跨域访问默认不能获取全部头部信息)
                        .maxAge(3600);  // 预请求的结果有效期,默认1800分钟,3600是一小时
            }
        };
    }
}

原因三:服务器未设置 Access-Control-Allow-Origin 响应头

如果目标服务器未设置 Access-Control-Allow-Origin 响应头,浏览器也不会发送 cookie。需要确保服务器设置了正确的 Access-Control-Allow-Origin 响应头,允许请求的来源域名。例如,在Node.js中使用Express框架:

app.use(function(req, res, next) {
  res.header('Access-Control-Allow-Origin', 'http://example.com');
  res.header('Access-Control-Allow-Credentials', true);
  next();
});

更多设置方式,请参考原因二。

业精于勤,荒于嬉。——韩愈《进学解》
1 不喜欢
说说我的看法 -
全部评论(
没有评论
关于
本网站专注于 Java、数据库(MySQL、Oracle)、Linux、软件架构及大数据等多领域技术知识分享。涵盖丰富的原创与精选技术文章,助力技术传播与交流。无论是技术新手渴望入门,还是资深开发者寻求进阶,这里都能为您提供深度见解与实用经验,让复杂编码变得轻松易懂,携手共赴技术提升新高度。如有侵权,请来信告知:hxstrive@outlook.com
公众号