Multer没有通过快速通道

时间:2017-01-12 22:07:47

标签: express multer multer-s3

我尝试使用Multer将图像上传到文件系统。请查看我的路线中的相关数据:

const
  ..
  multer = require('multer'),
  ..;

const storage = multer.diskStorage({
    destination: function (req, file, callback) {
      callback(null, './uploads');
    },
    filename: function (req, file, callback) {
      callback(null, req.params.id + file.originalname);
    }
  }),
  upload = multer({storage: storage}).single('profilePic');

router.put(
  '/:id',
  middleware.isLoggedIn,
  (req, res, next) => {

    User
      .findByIdAndUpdate(
        req.params.id, req.body.user,
        (err, updatedUser) => {
          if (err) {
            return req.flash('error', err.message);
          }

          upload(req, res, (err) => {
            if (err) {
              eval(locus);
              return req.flash('error', err.message);
            }
            updatedUser = req.body.user;
            eval(locus);

            //redirect show page
            res.redirect('/dashboard/profile/' + req.params.id + '/edit');
          });
        });
  });

module.exports = router;

当我查看updatedUser时,我看到的第一件事是 { profilePic: 'data:image/jpeg;base64,....}我做错了什么?由于我在这里有上传功能,它甚至都没有更新页面。我真正想做的是让目标在s3上工作,但我需要首先保存它。

1 个答案:

答案 0 :(得分:2)

因此,这是使用multer上传图片的最基本示例:

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

var storage = multer.diskStorage({
  // define where the file should be uploaded, else it will be uploaded to the system temp dir
  destination: function (req, file, cb) {
    // ./uploads should be created beforehand
    cb(null, './uploads')
  },
  // define "filename", else a random name will be used for the uploaded file
  filename: function (req, file, cb) {
    cb(null, file.fieldname + '-' + file.originalname)
  }
})

var upload = multer({ storage: storage })

// pic is the name of image field in the form
app.put('/profile', upload.single('pic'), function (req, res, next) {
  console.log(req.file)
  res.send('Uploaded')
})

app.listen(3000)

这是一个示例curl命令,用于将图像从文件系统上传到上面的应用程序:

curl -X PUT -F 'pic=@/projects/eg/foto.png' localhost:3000/profile

确保示例正常运行,以确保您了解multer处理文件上传的方式,以及问题不在multer

说完了,User.findByIdAndUpdate似乎将图像数据存储为某处的base64编码字符串;我不知道User.findByIdAndUpdate连接到什么。它超出了multer的范围。

我们的Gitter频道(https://gitter.im/expressjs/express)上有人可能会提出建议。加入我们。