web-dev-qa-db-ja.com

MulterおよびExpress / Nodeファイルのアップロード

req.filesはnullを生成し、req.bodyも空白になります。ここですべての答えを検索しましたが、あまり見つかりません。残念ながら、Multerのドキュメントはかなり不足していたので、うまくいけば、誰かが私が今何をしているかを経験し、何が起こっているのかを知っています。

私のrouter.jsファイルはこれです:

var express = require('express');
var request = require('request');
var mid = require('../middleware');
var busboy = require('connect-busboy');
var fs = require('fs');
var multer = require('multer');
var upload = multer({dest: '../public/images/blog'});
var User = require('../data/models/user');
var router = express.Router();
...
...
...
...
/* POST saveblog router. */
router.post('/saveBlog', upload.any(),function(req, res, next) {
  console.log(req.body, 'Body'); 
  console.log(req.files, 'files');
  var title = req.body.titleInput;
  var body = req.body.bodyInput;
  request.post('http://' +req.headers.Host + '/api/blog', {json: {body: body, title: title, userId: req.session.userId}},
  function(err, httpResponse, body) {
    if (err) {
      console.error('error posting blog');
    }
    console.log('Blog Post successfully uploaded');
  });
  return res.redirect('/blog');
}); 

module.exports = router;

だから私はそれの何が悪いのか完全にはわかりません、私はもともとそれをupload.single( 'image')として持っていましたが、それはどちらもうまくいかなかったので誰が知っていますか?.

ここに提出する私のヒスイのフォームがあります。誰かが助けることができるがヒスイが好きではない場合、私はそれのための簡単なコンバータを見つけることができると確信しています。

form(action='saveBlog', enctype='multipart/form-data', method='post')
  h1 New Blog Post 
  fieldset(data-role='')
    label(for='title') Title 
    input(id='titleInput', name='titleInput', type='text', value='', placeholder='Your Title', require='true').form-control
    label(for='image') Your Title Image
    input(id='image',name='image', type='file', accept='image/*')
    br
    label(for='body') Your Article (Box is resizable)
    textarea(id='mytextarea', name='bodyInput').form-control
    input(type='submit', value='Post your Article').btn.btn-primary
7
matt.condit

今日はこれに取り組んでいます。私が気づいたことの1つは、あなたがupload.single()を使用していることです。探しているデータはreq.fileないreq.files

それがあなたの問題かどうかはわかりません。

ちなみに、このスリム化された例は私にとってはうまくいきます:

server.js

var express = require('express');
var app = express();

app.use(require('./routes'));

app.listen(8080);

routes.js

var express = require('express');
var multer = require('multer');
var upload = multer({ dest: '/tmp/' });
var router = express.Router();

/* POST saveblog router. */
router.post('/saveBlog', upload.any(), function(req, res, next) {
  console.log(req.body, 'Body');
  console.log(req.files, 'files');
  res.end();
});

module.exports = router;

私はポストマンから投稿し、この出力を得ました:

{ test: '1' } 'Body'
[ { fieldname: 'asdas',
    originalname: 'vcenter.png',
    encoding: '7bit',
    mimetype: 'image/png',
    destination: '/tmp/',
    filename: '92f425268efaa45cad31f67ec8f14c2d',
    path: '/tmp/92f425268efaa45cad31f67ec8f14c2d',
    size: 54834 } ] 'files'
12
Dave

req.fileからreq.files。それは私のために働いた。

0