gpt4 book ai didi

javascript - 如何通过 jQuery 将文件 POST 到 nodejs connect-busboy

转载 作者:行者123 更新时间:2023-12-01 03:21:51 24 4
gpt4 key购买 nike

我可以使用 HTML 表单的操作属性成功地将文件发送到 connect-busboy,如下所示:

<form ref='uploadForm' method="post" action="http://localhost:3000/fileupload" enctype="multipart/form-data" id='uploadForm'>
Select file to upload:
<input type="file" name="sampleFile">
<input type="submit" value="Upload!">
</form>

但是,我不希望页面重定向。

我尝试通过删除表单标记中的 action 属性并添加带有以下内容的 onclick 函数来将其转换为 jQuery:

$.ajax({
url:'http://localhost:3000/fileupload',
type:'post',
contentType: 'multipart/form-data',
data:$('#uploadForm').serialize(),
success:function(){
alert('Success');
},
error: function() {
alert('Error');
},
});

不幸的是,这不适用于以下错误:

TypeError: Cannot read property 'end' of undefined

Nodejs代码如下:

const express = require('express');
const busboy = require('connect-busboy');
const app = express();
app.use(busboy());
const fs = require('fs');

app.post('/fileupload', function(req, res) {
var fstream;
req.pipe(req.busboy);
req.busboy.on('file', function (fieldname, file, filename) {
console.log("Uploading: " + filename);
fstream = fs.createWriteStream(__dirname + '/files/' + filen ame);
console.log(fstream);
file.pipe(fstream);
fstream.on('close', function () {
res.send('Success');
});
});
});

var port = process.env.PORT || 3000;
app.listen(port);

完整错误:/image/cO9MU.png

最佳答案

通过显式序列化表单,您隐式地避免/删除了多部分/表单数据格式。相反,将 FormData 实例作为 data 传递。您可以从现有表单实例化新的 FormData,例如:

var data = new FormData($('#uploadForm')[0]);

$.ajax({
url: 'http://localhost:3000/fileupload',
type: 'POST',
contentType: false,
processData: false,
cache: false,
data: data,
success: function() {
alert('Success');
},
error: function() {
alert('Error');
}
});

关于javascript - 如何通过 jQuery 将文件 POST 到 nodejs connect-busboy,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45134114/

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