【发布时间】:2020-05-08 23:56:41
【问题描述】:
我的浏览器正在 devtools 控制台中记录以下消息:
请求的资源上不存在“Access-Control-Allow-Origin”标头。...响应的 HTTP 状态代码为 503。
背景:我有两个应用程序。一个是连接到 Mongo 数据库的 Express Node 应用程序。另一个是基本的 Web 应用程序,它通过 Fetch API 向 Node 应用程序发出 POST 请求,以从 Mongo 获取数据。
问题:虽然我在本地计算机上没有收到 CORS 错误,但在将基本 Web 应用程序部署到生产环境后,我会立即收到以下错误。 Web 应用程序向 Node 应用程序发出 POST 请求并给我这个:
POST 请求似乎确实有效,并且数据已保存到 Mongo 中,但此错误在 Heroku 中被标记为“严重错误”,非常烦人。
我意识到我可以在 Fetch 中设置 no-cors 选项,但我认为这是必需的,因为我正在向与来源不同的 url 发出请求。对吧?
Express 节点应用代码
在我的app.js 文件中,我设置了正确的标头,以确保其他应用程序可以发出来自不同来源的请求
app.js
// Add headers so we can make API requests
app.use(function (req, res, next) {
res.setHeader('Access-Control-Allow-Origin', '*');
res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS, PUT, PATCH, DELETE');
res.setHeader('Access-Control-Allow-Headers', 'X-Requested-With,content-type');
res.setHeader('Access-Control-Allow-Credentials', true);
next();
});
routes/api/api.js
router.post('/users/:url/upload-csv/:csv_name', (req, res) => {
let csv_name = req.params.csv_name;
let csv_string = csv_name+req.body.csv_string;
User.findOne({url: req.params.url})
.then((user) => {
if (user.csv_files.length === 0) {
user.csv_files.push(csv_string);
} else {
let foundExistingCSV = false;
for (var i = 0; i < user.csv_files.length; i++) {
if (user.csv_files[i].includes(csv_name)) {
foundExistingCSV = true;
user.csv_files[i] = csv_string;
break;
}
}
if (!foundExistingCSV) user.csv_files.push(csv_string);
}
user.markModified('csv_files');
user.save();
res.status(204);
})
.catch((err) => {
console.log(err);
res.status(400);
});
});
基本网络应用代码
POST 我提出的请求
utils.js
utils.exportToMongo = functions(table, name) {
var exportPlugin = table.getPlugin('exportFile');
var csv_string = exportPlugin.exportAsString('csv');
// Upload the CSV string and its name to Users DB
fetch(`${utils.fetchUserURL()}/upload-csv/${name}`, {
method: 'POST',
body: JSON.stringify({csv_string: csv_string}),
headers: new Headers({
'Content-Type': 'application/json',
Accept: 'application/json',
})
}).then((res) => {
return {};
}).catch((error) => {
console.log(error);
return {};
});
}
如何消除503 错误?任何见解将不胜感激!
【问题讨论】:
-
尝试更改您的 CORS 设置以匹配此设置:enable-cors.org/server_expressjs.html
标签: javascript node.js cors fetch-api