使用multer上传时如何限制文件大小?

时间:2016-01-09 18:46:46

标签: node.js express multer

我正在使用multer创建一个简单的文件上传系统:

var maxSize = 1 * 1000 * 1000;

var storage = multer.diskStorage({
  destination: function (req, file, callback) {
    callback(null, 'public/upload');
  },
  filename: function (req, file, callback) {
    callback(null, file.originalname);
  },
  onFileUploadStart: function(file, req, res){
    if(req.files.file.length > maxSize) {
      return false;
    }
  }

});

var upload = multer({ storage : storage}).single('bestand');

router.post('/upload',function(req,res){
    upload(req,res,function(err) {
        if(err) {
            return res.end("Error uploading file.");
        }
        console.log(req.file);
        res.redirect(req.baseUrl);
    });
});

一切正常,文件上传。唯一不起作用的是最大尺寸的限制。我这样做是为了让onfileupload启动文件的大小得到检查,如果它变大,它将返回false。但该文件仍然上传。

似乎onFileUploadStart根本没有做任何事情。我尝试了console.log内容,但没有。

我做错了什么?使用multer上传时如何限制文件大小?

2 个答案:

答案 0 :(得分:35)

onFileUploadStart API没有multer。如果要限制文件大小,则应将limits: { fileSize: maxSize }添加到传递给multer()的对象:

var upload = multer({
  storage: storage,
  limits: { fileSize: maxSize }
}).single('bestand');

答案 1 :(得分:2)

我想是你在找。 祝您有美好的一天。

const fileFilter = (req, file, cb) => {

const fileSize = parseInt(req.headers['content-length']);

if((file.mimetype === 'image/png' || file.mimetype === 'image/jpg' || file.mimetype === 'image/jpeg' || file.mimetype === 'application/octet-stream') && (fileSize <= 1282810)) {

cb(null, true);

} else if(file.mimetype === 'video/mp4' && fileSize <= 22282810) {

cb(null, true);

}

else {

cb(null, false);

}

};