2016-07-11 14 views
1

Die multiparty.Form() funktioniert nicht. Ich versuche zu drucken. (Zum Beispiel 2,3,4)Node.js Multiparty-Upload funktioniert nicht

Hier ist mein Bild-Upload-Code:

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); 

    }); 
}); 

Es scheint, wie die form.on Methode funktioniert nicht.

Wohin gehe ich falsch?

+0

können Sie mir sagen, an welchem ​​Punkt der Code erreichen – Jain

+0

Ja, nur '1' in dieser – diksha

+0

Verwendung druckt diese direkt nach Konsole. var form = neue multiparty.Form(); form.parse (req, Funktion (Fehler, Felder, Dateien) { res.writeHead (200, {'Inhaltstyp': 'text/plain'}); res.write ('empfangene Upload: \ n \ n '); res.end (util.inspect ({Felder: Felder, Dateien: Dateien})); }); Rückkehr; – Jain

Antwort

0

es einfach verwenden:

// 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; 

Quelle: https://www.npmjs.com/package/multiparty

+0

@Diksha, versuchen Sie diese Hoffnung, es wird einige Fehler zur Verfügung stellen, so können Sie mehr debuggen form.on ('Fehler', Funktion (err) { console.log (err); }); – Jain

+0

Ich kann auf die Dateien zugreifen, aber es gibt nur Name und Pfad ohne Daten: files:% @ {fieldName: 'image', originalDateiname: 'photo1.png', Pfad: '/ var/folders/x4/01z7j18d7vz8rxrgcxt2w9dm0000gn/T/OMTuSjvM_Oj9OeUr44z0Mzk4.png ', Kopfzeilen: {' content-disposition ':' Formulardaten; Name = "Bild"; filename = "photo1.png" ', ' content-type ':' image/png '}, size: 152501} Wissen Sie, wie ich auf die übertragenen Bilddaten zugreifen kann, nicht nur den Pfad, um sie in der Datenbank? –

Verwandte Themen