2016-07-11 8 views
1

multiparty.Form()が機能しません。私は印刷しようとしています。Node.jsマルチパートアップロードが機能していません

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方法のように思える。(例えば2,3,4)

はここに私の画像アップロードのコードです。

どこが間違っていますか?

+0

あなたは私を伝えることができ、あなたのコードは – Jain

+0

に達するどの時点でははい、唯一の「1」だけで、コンソールの後、この – diksha

+0

使用でこれを印刷しています。 var form = new multiparty.Form(); res.write( '受信したアップロード:\ n)res.writeHead(200、{' content-type ':' text/plain '}); \ n '); res.end(util.inspect({フィールド:フィールド、ファイル:ファイル})); }); return; – Jain

答えて

0

ちょうどそれを使用します。

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

+0

@diksha、この希望を試してください。何らかのエラーが出るので、もっとデバッグできます。 form.on( 'error'、function(err){ console.log(err); });ファイル:%@ {fieldName: 'image'、 originalFilename: 'photo1.png'、 パス: '/ var/folders/x4/ – Jain

+0

ファイルにアクセスできますが、データは表示されません。 01z7j18d7vz8rxrgcxt2w9dm0000gn/T/OMTuSjvM_Oj9OeUr44z0Mzk4.png '、 ヘッダー: {' content-disposition ':' form-data;名前= "イメージ";ファイル名を「photo1.png」、 「content-type」:「image/png」}、 サイズ:152501}パスに保存されているイメージデータにアクセスして、データベース? –

関連する問題