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退出命令行后,再重新启动服务器(必须退出之后再重启才会生效 

文章来源地址https://uudwc.com/A/woyPj

原文地址:https://blog.csdn.net/Ls0204_/article/details/132170911

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请联系站长进行投诉反馈,一经查实,立即删除!

上一篇 2023年09月25日 06:36
《C++ Core Guidelines解析》——图书推荐
下一篇 2023年09月25日 06:41