我需要在React UI中使用来自用户的文件(使用axios),使用Express通过POST将此文件发送到NodeJS方法然后,我需要通过POST将此文件直接发送到另一个API(。 NET WebAPI)没有保存在磁盘上。我正在尝试直接传递数据文件(req.files.file.data),但.NET API无法识别请求中的文件。
是否有可能在“var”中创建临时文件并像从磁盘读取文件时那样发送它?
此示例适用于本地文件:
var formData = {
form: "{ abn: '666666666' }",
files: JSON.stringify([
{
name: "file1",
type: "1",
number: "6666"
},
{
name: "file2",
type: "3",
number: "3333"
},
]),
// Pass multiple values /w an Array
attachments: [
fs.createReadStream(__dirname + '/../file1.txt'),
fs.createReadStream(__dirname + '/../file2.txt')
],
};
var reqs = request.post({url:'https://tms-dev-api.micway.com.au/api/company/file', formData: formData, json: true}, function optionalCallback(err, response, body) {
if (err) {
return res.send(err);
}
return res.send({
status: response.statusCode,
body: body
});
});
我正在创建一个本地文件,然后通过它发送;但是,我不相信这是最好的方法。像这样:
router.post('/file', function(req, res) {
var fstream;
req.pipe(req.busboy);
req.busboy.on('file', function (fieldname, file, filename) {
fstream = fs.createWriteStream(__dirname + '/' + filename);
file.pipe(fstream);
var formData = {
attachments: [
fs.createReadStream(__dirname + '/' + filename)
],
};
var reqs = request.post({url:'https://tms-dev-api.micway.com.au/api/company/file', formData: formData, json: true}, function optionalCallback(err, response, body) {
if (err) {
return res.send(err);
}
console.log({
status: response.statusCode,
body: body
})
return res.send({
status: response.statusCode,
body: body
});
});
});
});
谢谢!