1

multer.js在我的项目中使用用户注册时上传用户个人资料图片。

我需要存储用户图像文件并制作缩略图。制作缩略图时,我使用的是gm.js. 以下是我的代码。

import { Router } from 'express';
import User from '../models/user.model';
import passport from 'passport';
import gm from 'gm';
import multer from 'multer';

const router = new Router();

const upload = multer({ dest: './static/img/user/' });

const _saveThumbnail = (fileName) => {
  return new Promise((resolve, reject) => {
    gm(`img/user/${fileName}`).thumb(48, 48, `img/user/thumb_${fileName}`, 100, (err) => {
      if (err) reject(new Error(err));
      resolve();
    });
  });
};

router.post('/api/users', upload.single('img'), (req, res) => {

  const fileName = req.file ? req.file.filename : 'default.png';

  Promise.all([_getColRank(4), _getBattleRank(1000)]).then((ranks) => {
    const user = new User({
      email: req.body.email,
      nickname: req.body.nickname,
      password: req.body.password,
      img: fileName,
      introduce: req.body.introduce,
      recommender: req.body.recommender,
      colPoint: 4,
      colRank: ranks[0],
      battleRank: ranks[1],
    });

    _saveThumbnail(fileName).then(() => {
      User.register(user, user.password, (err, savedUser) => {
        if (err) return res.status(500).send(err);
        passport.authenticate('local')(req, res, () => {
          res.json({ savedUser });
        });
      });
    });
  });
});

export default router;

我假设upload.single('img')post的中间件,完成上传图片,所以gm把上传的图片做缩略图。但什么也没有发生。_saveThumbnail返回resolve()并且原始图像已上传。

我真的很想做缩略图。帮我。

4

1 回答 1

2

我找到了答案。错误的点是图像路径。

我改变了我的代码如下。

import { Router } from 'express';
import User from '../models/user.model';
import passport from 'passport';
import gm from 'gm';
import multer from 'multer';

const router = new Router();

const upload = multer({ dest: './static/img/user/' });

const _saveThumbnail = (imagePath) => { // edited arg
  return new Promise((resolve, reject) => {
    gm(imagePath).thumb(48, 48, `${imagePath}_thumb`, 100, (err) => { // edited
      if (err) reject(new Error(err));
      resolve();
    });
  });
};

router.post('/api/users', upload.single('img'), (req, res) => {

  const fileName = req.file ? req.file.filename : 'default.png';
  const imagePath = req.file ? req.file.path : null; // added
  Promise.all([_getColRank(4), _getBattleRank(1000)]).then((ranks) => {
    const user = new User({
      email: req.body.email,
      nickname: req.body.nickname,
      password: req.body.password,
      img: fileName,
      introduce: req.body.introduce,
      recommender: req.body.recommender,
      colPoint: 4,
      colRank: ranks[0],
      battleRank: ranks[1],
    });

_saveThumbnail(imagePath).then(() => { // edited arg
  User.register(user, user.password, (err, savedUser) => {
    if (err) return res.status(500).send(err);
    passport.authenticate('local')(req, res, () => {
      res.json({ savedUser });
    });
  });
});
  });
});

导出默认路由器;

于 2016-06-22T13:43:55.240 回答