如何解决对预检请求未通过访问控制检查错误的问题响应?



我在虚拟机中有一个角度代码,在另一个虚拟机中有一个节点代码。我需要从这个角度虚拟机到节点虚拟机进行 API 调用。我也包括了 cors 模块。但是在进行 API 调用时,仍然收到类似

"从

源"http:IP2"访问 'http:IP1' 处的 XMLHTTP请求已被 CORS 策略阻止:对预检请求的响应未通过访问控制检查:无"访问控制"。

我也设置了这样的标题,

app.use(function(req,res,next) {
res.setHeader('Access-Control-Allow-Origin','*');
res.setHeader('Access-Control-Allow-Methods','POST');
res.setHeader('Access-Control-Allow-Headers','X-Requested-With,content-type');
res.setHeader('Access-Control-Allow-Credentials',true);
next();
}); 
app.use(cors());

但我仍然面临一个错误。谁能告诉我如何解决这个错误?

尝试显式设置本地主机并添加所需的方法类型:

// Add headers
app.use(function (req, res, next) {
// Website you wish to allow to connect
res.setHeader('Access-Control-Allow-Origin', 'http://localhost:4200');
// desired types of methods
res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS, PUT, PATCH, DELETE');
res.setHeader('Access-Control-Allow-Headers', 'X-Requested-With,content-type');
// Set to true if you need the website to include cookies in the requests sent
// to the API (e.g. in case you use sessions)
res.setHeader('Access-Control-Allow-Credentials', true);
// Pass to next layer of middleware
next();
});

更新:

例如,您的节点服务器托管在http://127.0.0.1:8000。那么你的角度应用程序应该是http://127.0.0.1:4200的。

更新 1:

npm install --save cors

然后:

var express = require('express');
var cors = require('cors');
var app = express();
app.use(cors());

相关内容

最新更新