【问题标题】:Node.js multiparty upload is not workingNode.js 多方上传不起作用
【发布时间】:2016-07-11 05:18:56
【问题描述】:

multiparty.Form() 不工作。我正在尝试打印。 (例如 2,3,4)

这是我的图片上传代码:

app.post('/gallery/add',function(req, res,next) {
var input = JSON.parse(JSON.stringify(req.body));
var multipart = require('connect-multiparty');
var multiparty = require('multiparty');
var format = require('util').format;
var fs = require("fs");
var path = require('path');
var tempPath =req.files.image.path;
var filename2 =req.files.image.originalFilename;
req.getConnection(function (err, connection) {
    console.log('1');
   var form = new multiparty.Form();
   var image;
   var title;
form.on('error', next);
  form.on('close', function(err, fields, files){
      console.log('2');
      if(err) {
       next(err);
       console.log(err);
    } else {
  console.log('3');
      ins = fs.createReadStream(tempPath);
      ous = fs.createWriteStream(__dirname + '/uploads/' + image.filename);
      util.pump(ins, ous, function(err) {
        if(err) {
          next(err);
        } else {
          res.redirect('/#gallery/add');
          res.end();
        }
      });
      //console.log('\nUploaded %s to %s', files.photo.filename, files.photo.path);
      //res.send('Uploaded ' + files.photo.filename + ' to ' + files.photo.path);
    }
    res.send(format('\nuploaded %s (%d Kb) as %s'
      , image.filename
      , image.size / 1024 | 0
      , title));
  });
 // listen on field event for title
  form.on('field', function(name, val){

  console.log('4');
    if (name !== 'title') return;
    title = val;
  });

  // listen on part event for image file
  form.on('part', function(part){
 console.log('5');
    if (!part.filename) return;
    if (part.name !== 'image') return part.resume();
    image = {};
    image.filename = part.filename;
    image.size = 0;
    part.on('data', function(buf){
      image.size += buf.length;
    });
  });

  // parse the form
   form.parse(req);

    });
});

form.on 方法似乎不起作用。

我哪里错了?

【问题讨论】:

  • 你能告诉我,你的代码在什么时候到达
  • 是的,这里只打印了“1”
  • 在控制台之后使用这个。 var form = new multiparty.Form(); form.parse(req, function(err, fields, files) { res.writeHead(200, {'content-type': 'text/plain'}); res.write('received upload:\n\n') ; res.end(util.inspect({fields: fields, files: files})); });返回;
  • 是否有效??
  • 不,它说字段和文件未定义。

标签: javascript angularjs node.js express


【解决方案1】:

随便用吧:

// parse a file upload 
    var form = new multiparty.Form();

    form.parse(req, function(err, fields, files) {
      res.writeHead(200, {'content-type': 'text/plain'});
      res.write('received upload:\n\n');
      res.end(util.inspect({fields: fields, files: files}));
    });

    return;

来源:https://www.npmjs.com/package/multiparty

【讨论】:

  • @diksha,试试这个希望它会提供一些错误,所以你可以调试更多 form.on('error', function(err){ console.log(err); });
  • 我可以访问这些文件,但是只有名称和路径,没有出现数据:文件:%@ { fieldName: 'image', originalFilename: 'photo1.png', path: '/var /folders/x4/01z7j18d7vz8rxrgcxt2w9dm0000gn/T/OMTuSjvM_Oj9OeUr44z0Mzk4.png',标题:{'content-disposition':'form-data;名称=“图像”; filename="photo1.png"', 'content-type': 'image/png' }, size: 152501 } 你知道我怎样才能访问提交的图像数据而不仅仅是路径以便将它们存储在数据库中吗?
猜你喜欢
  • 1970-01-01
  • 2017-09-01
  • 2015-03-09
  • 2021-06-14
  • 1970-01-01
  • 2016-06-08
  • 1970-01-01
  • 2016-02-20
相关资源
最近更新 更多