我正在使用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上传时如何限制文件大小?
答案 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);
}
};