发送带有axios和强大的图像(nodejs-> express)

问题描述 投票:0回答:1

我正在尝试使用axios(nodejs)发送图像来表示具有强大功能的服务器。这是axios脚本的代码:

const axios = require('axios');
const fs = require('fs')
const FormData = require('form-data')

var img = fs.readFileSync("C:/Users/alessio/Documents/FX/screenshot.png", 'utf8'); 
console.log(img)
let data = new FormData();
data.append('img', img, "img.png")
console.log(data);
axios.post('http://192.168.43.193:3000/testAPI/upload_img_mt', data, {
    headers: {
        'accept': 'application/json',
        'Accept-Language': 'en-US,en,q=0.8',
        'Content-Type': `multipart/form-data; boundary=${data._boundary}`,
        'timeout': 999999
    },
})
    .then(function (response){
        //console.log(response);
    })

这是带有express的代码服务器端,并且具有强大的管理响应:

router.post('/upload_img_mt', function(req, res, next){
    console.log(req)

    var form = new formidable.IncomingForm();
    form.uploadDir = "fxdiary";
    form.encoding = 'utf8';
    form.on('fileBegin', function(name, file){
        console.log(form.uploadDir + "/" + file.name);
    });
    form.parse(req, function(err, fields, files) {
        console.log(files);
        console.log(err);
        console.log(fields);
    });
    res.sendStatus(200);
});

文件图像已保存,但不是正确的png图像。图像尺寸不正确,有时会随机变化。广告示例的原始文件大小为33k,变为900bytes或54k或其他值。

发生了什么?此代码中的问题出在哪里?

node.js express axios formidable
1个回答
0
投票

您不需要在Content-type标头中传递边界,因为它是由浏览器自动添加的。您可能会破坏默认边界机制。

如果您仍然遇到文件大小问题,请尝试使用multer模块在Node.js端进行文件处理

© www.soinside.com 2019 - 2024. All rights reserved.