如何在使用多媒体上传时限制文件大小?
我正在用一个简单的file upload系统:
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); }); });
这一切工作正常,file upload。 唯一不起作用的是最大尺寸的限制。 我做了这样的onfileupload开始文件的大小得到检查,如果它大,它将返回false。 但该文件仍然只是上传。
看来onFileUploadStart
就没有做任何事情。 我试图console.log
东西,但没有。
我究竟做错了什么? 如何在用multer上传时限制文件大小?
新的multer
API没有onFileUploadStart
。 如果你想限制文件大小,你应该向传递给multer()
的对象添加limits: { fileSize: maxSize }
:
var upload = multer({ storage: storage, limits: { fileSize: maxSize } }).single('bestand');