解决axios跨域请求成功却报错的问题

本文探讨了在使用axios进行跨域请求时遇到的问题,详细分析了错误原因,包括Access-Control-Allow-Origin和Access-Control-Allow-Credentials的冲突。并提供了解决方案,即修改前端axios配置以适应后端接口的跨域设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题

今天在联调后端接口的时候,通过chrome调试工具可以看到接口数据返回正常,状态200,可是返回仍然被axiosonRejected 拦截了。无法获取请求结果,并在chrome控制台上可以看到如下错误。

Failed to load http://localhost:8007/wenjuan/1: The value of the ‘Access-Control-Allow-Origin’ header in the response must not be the wildcard ‘*’ when the request’s credentials mode is ‘include’. Origin ‘http://xxxxxgbl.org’ is therefore not allowed access. The credentials mode of requests initiated by the XMLHttpRequest is controlled by the withCredentials attribute.

原因

本来用的是代理转发,后来后端调整专用的/api开头的域名,并允许跨域请求。然后就出现了这个问题。
下图是后端接口的配置。
这事在这里插入图片描述
这里是前端的axios 配置。
在这里插入图片描述

知识点

axios发送请求的时候,默认是不会带上cookie的,如果需要带cookie,需要通过设置withCredentials: true来解决。
并且需要后端配置做如下设置:

  • header信息 Access-Control-Allow-Credentials:true
  • Access-Control-Allow-Origin不可以为 *,因为 * 会和 Access-Control-Allow-Credentials:true 冲突
解决

通过修改前端和后端都可以解决,具体修改方式取决于项目的具体情况。

因为这个项目前后端交互完全使用token,所以不需要传递cookie了,修改axios配置即可:

// 去掉该配置
// axios.defaults.withCredentials = true;
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值