gpt4 book ai didi

javascript - 无法使用 JavaScript 提取 API 发布数据

转载 作者:行者123 更新时间:2023-11-29 14:42:27 25 4
gpt4 key购买 nike

我正在尝试使用 fetch API 将数据POST 到我的服务器,但每次我这样做都以空主体结束。

据我所知 fetch documentation , 要发布数据,您需要传递一个方法键设置为“POST”的对象和一个带有字符串或 FormData 对象(或其他一些对象)的正文键。

这是一个简单的例子,它没有像我预期的那样工作:

var formData = new FormData();
formData.append("test", "woohoo");
formData.append("foo", "bar")
// prints out contents of formData to show that it has contents!
formData.forEach(function(key, value) {
console.log(`${key}: ${value}`);
});

fetch("/fetch", {
method: "POST",
body: formData
}).then(function(response) {
return response.json();
}).then(function(json) {
// Logs empty object
console.log(json);
}).catch(function(err) {
console.log(err);
});

我在它的背后还有一个快速服务器,它记录请求正文并在响应中回显它。

app.post("/fetch", function(req, res) {
// Logs empty object :(
console.log(req.body);
res.send(JSON.stringify(req.body));
});

我将 formData 添加为 fetch 请求的主体,但似乎什么都没有通过。

Please find my test files in this gist here并提供帮助!

最佳答案

这是因为您的节点服务器没有正确理解多部分表单(这是 FormData)默认发送的内容。

您可以使用 node-muliparty在您的服务器上,您无需接触前端代码即可轻松阅读表单。

类似于:

var multiparty = require('multiparty');
var app = express();

app.post("/fetch", function(req, res) {
var form = new multiparty.Form();

form.parse(req, function(err, fields, files) {
console.log(fields);
res.send(JSON.stringify(fields));
});
});

在您的 index.js 中会显示它正常工作。可能有一种方法可以让 body-parser 工作,但我自己也不知道。

关于javascript - 无法使用 JavaScript 提取 API 发布数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36918287/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com