koa2 使用 koa2-cors 库配置跨域无效的问题

本文介绍了在Koa2中使用koa2-cors库配置跨域后仍然遇到问题的原因和解决方案。问题源于fetch请求时设置了credentials字段。去除该字段配置后,跨域问题得到解决。此外,扩展部分提到axios请求库因其使用xhr方式,不受此问题影响,能正常获取数据。

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

参考:MDN fetch

服务端配置

const cors = require("koa2-cors");

app.use(cors())

服务端这样配置后,前端页面访问接口还是报跨域的问题。

原因

由于我使用的是 fetch 去请求接口,且配置了 credentials 字段,代码如下:

fetch('http://192.168.1.111:3000/api/flow', {
  credentials: 'include',
})
.then(res => {
  return res.json();
})
.then(json => {
  console.log('获取的结果', json);
  return json;
})

解决

只需要将 credentials 字段的配置去掉就可以请求到服务端的接口数据了。

扩展

使用 axios 这样的请求库直接请求接口是可以获取到数据的,因为 axios 使用的是 xhr 的方式,和 fetch 不一样。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值