express跨域问题—Access to XMLHttpRequest at ‘http://localhost:8080/xxx’ from origin ‘http://localhost:xx

当我实现前后端分离的时候,遇到了这个问题:
Access to XMLHttpRequest at ‘http://localhost:8080/xxx’ from origin ‘http://localhost:xxx’ has been blocked by CORS policy: No ‘Access-Control-Allow-Origin’ header is present on the requested resource.

 一、报错

出现这条信息就是说明出现express跨域问题 。

这表明我们的请求已经成功发送到服务器端且服务器端对此进行了响应,但由于同源策略,我们并不能观察到响应内容。

注:同源策略详情可看Express 通过 CORS 或 JSONP 解决跨域问题_express解决跨域_BinaryMoon的博客-CSDN博客

二、解决 

两种方法:(1).安装cors中间件;(2)手动实现。

方法一:安装cors中间件(推荐)

1、安装cors插件

// 项目根目录下运行下列命令行
    npm install --save cors

2、 服务器的主文件中导入cors

// 后端解决跨域导入cors包
    const cors = require('cors');
// 解决跨域
    app.use(cors());  

3、ctrl+c退出命令行后,再重新启动服务器(必须退出之后再重启才会生效 )

npm start

 方法二:手动实现

路由文件中app.get前加入如下代码:

app.use((req, res, next) => {
res.header('Access-Control-Allow-Origin', '*')
res.header('Access-Control-Allow-Headers', 'Authorization,X-API-KEY, Origin, X-Requested-With, Content-Type, Accept, Access-Control-Request-Method' )
res.header('Access-Control-Allow-Methods', 'GET, POST, OPTIONS, PATCH, PUT, DELETE')
res.header('Allow', 'GET, POST, PATCH, OPTIONS, PUT, DELETE')
next();
});

 

 后端服务器ctrl+c退出命令行后,再重新启动服务器(必须退出之后再重启才会生效 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值