关于浏览器怎么保存跨域请求中cookie的问题

        今天在开发项目的登录功能的时候,由于我的前端项目和后端项目是运行在不同的端口上,因此有着跨域请求。而我发现当我想把登录成功后的cookie返回给浏览器时,虽然响应标头中包含了set_cookie的值,但是cookie始终不能保存在浏览器上。
        经过我几个小时的反复上网查找资料,终于找到了解决方法,分为以下三点:

  1. 服务器要设置正确的 CORS 配置: 服务器必须在响应中包含 Access-Control-Allow-Credentials: true 头部,以允许客户端发送凭据。此外,还要确保 Access-Control-Allow-Origin 头部设置为请求源的值,而不是 *。例如,在 Django 中(我的后端项目是基于Django框架的),可以通过设置 CORS_ALLOW_CREDENTIALSCORS_ORIGIN_WHITELIST 来实现。
    在Django的settings设置中加入这两个配置,下面的CORS_ORIGIN_WHITELIST里面加上自己前端项目的域名,或者使用CORS_ORIGIN_ALLOW_ALL,即允许所有域名的跨域请求。

  2. 客户端请求设置 withCredentialstrue 在客户端发送请求时,确保设置了 withCredentials: true,以便浏览器发送凭据。
    下面是我登录功能的简单示例,重点关注withCredentials部分

    login() {
          let data = this.loginForm;
          axios
            .post(
              "/login/",
              {
                email: data.email,
                password: data.password,
                code: data.code,
                uuid: this.uuid,
              },
              {
                headers: {
                  "Content-Type": "application/json",
                },
                withCredentials: true, // 在请求中包含凭据
              }
            )
            .then((res) => {
              if (res.data.success) {
                //登录成功
                this.$message.success(res.data.msg);
                this.enterHomePage();
              } else {
                //登录失败
                this.$message.error(res.data.error);
              }
            })
            .catch((err) => {
              console.log(err);
            });
        },
  3. 浏览器支持: 一些浏览器可能不支持在跨域请求中发送凭据,尤其是在第三方 Cookie 受到限制的情况下。确保浏览器支持并启用了此功能。

  • 10
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值