javascript - 在nodejs中发送带有上传文件的表单

标签 javascript node.js ajaxform jquery-upload-file-plugin

我使用busbody在nodejs中上传文件 我可以上传文件,但无法在 bodyparser 中收到短信 我的最后代码是:

<script>
    $("input[type='button']").click(function(){
    var files = $("input[type='file']").get();

    var formData = new FormData();
    var text  = "xxxxx";
    var url  = "fileUpload";
    if (files.length > 0){
      for (var i = 0; i < files.length; i++) {
        var input = $("input[type='file']").get(i).files;
        var file = input;
        if(file.length>0){
          console.log( file[0].name);
          formData.append('userpic',file[0], file[0].name);
        }
      }
      formData.append('text',text);
      $.ajax({
        type: "post",
        url: url,
        processData: false,
        contentType: false,
        data: formData, // serializes the form's elements.
      });
    }
  });
</script>

服务器.js

router.post('/fileUpload', function(req, res) {
console.log(req.body.text);
// req.pipe(req.busboy);
req.busboy.on('file', function(fieldname, file, filename) {
    console.log('ok2');
    var fstream = fs.createWriteStream('./public/images/' + filename);
    file.pipe(fstream);
    fstream.on('close', function () {

    });
});
res.send('upload succeeded!');
});

这行代码console.log(req.body.text); 只需返回{}

最佳答案

尝试使用主体解析器: npm install --save body-parser 然后选择中间件: var bodyParser = require('body-parser'); app.use(bodyParser.json());

或者直接使用中间件: var bodyParser = require('body-parser'); router.post('/fileUpload', bodyParser.json(), function(req, res) {....});

还可以尝试使用 console.log(req.body) 查看请求的格式。

关于javascript - 在nodejs中发送带有上传文件的表单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39598250/

相关文章:

JavaScript - 执行递归搜索,值不被保留

php - 删除出现在所有行中的相似字符

javascript - JQuery 我的函数只运行一次

javascript - 来自 ajax 表单的 XML 请求

ajax - 有没有推荐的ajax表单代码生成库或者app?

javascript - 如何传递 Promise 执行器数据?

node.js - 测试存储库代码时出现的问题(Node JS、webpack)

node.js - multiCapability 函数在 Protractor 中引发错误

node.js - https 上的 Socketio 使用 redis

reactjs - axios post请求发送表单数据