Nodejs-处理并发送多部分请求,

时间:2020-03-11 05:33:53

标签: node.js express

我的应用程序在Nodejs服务器上运行,Nodejs还充当来自该应用程序的请求的中间件/代理。因此,所有REST调用都从浏览器转到NodeJ,然后到Java API。

我看到一个处理包含多部分表单数据的请求的问题。

我在自己的nodejs中拦截来自浏览器的文件上传REST调用,使用多方库解析请求,并从文件上传请求中形成一个表单数据对象。

我正在使用https模块将数据发送到API,那么如何通过https将表单数据请求发送到API?

我将Content-Type作为multipart / form-data发送; boundary = ---- WebKitFormBoundary6fyv95baqEpoGJaK,来自浏览器。

var https = require('https');
var multiparty = require('multiparty');
var FormData = require('form-data');
app.post('/v1/filesUpload', (request, response) => {
let apiOptions ={
    headers: {
     'Content-Type': request.headers['Content-Type'],
      'host' : ...
      'path': ...    
     .
     .
     .
      }
}
let form = new multiparty.Form();
let formdataReq = new FormData();
 Object.keys(fields).forEach(function (name) {
          console.log('got field named ' + fields[name]);
          formdataReq.append(name, fields[name].toString());
        });

        formdataReq.append('file', JSON.stringify(files));    
        const req = https.request(apiOptions, (res) => {

        });    
        req.write(querystring.stringify(formDataReq));
      }catch (e) {
        console.log(e);
      }
    });

});

2 个答案:

答案 0 :(得分:2)

我认为您需要像这样插入标题:

const formData = new FormData();

..

await axios.post("{url}", formData, {
      headers: {
        "Content-Type": `multipart/form-data; boundary=${formData.getBoundary()}`,
      },
    });

答案 1 :(得分:1)

try this

const express = require("express");
const app = express();
const bodyParser = require('body-parser');
var multer  = require('multer')();
const FormData = require('form-data');
const axios = require('axios');
const fs = require('fs');

app.use(bodyParser.json());

app.post('/fileUpload' , multer.single('fileFieldName'), (req , res) => {
    const fileRecievedFromClient = req.file; //File Object sent in 'fileFieldName' field in multipart/form-data
    console.log(req.file)

    let form = new FormData();
    form.append('fileFieldName', fileRecievedFromClient.buffer, fileRecievedFromClient.originalname);

    axios.post('http://server2url/fileUploadToServer2', form, {
            headers: {
                'Content-Type': `multipart/form-data; boundary=${form._boundary}`
            }
        }).then((responseFromServer2) => {
            res.send("SUCCESS")
        }).catch((err) => {
            res.send("ERROR")
        })
})

const server = app.listen(3000, function () {
    console.log('Server listening on port 3000');
});