multer上传时如何限制文件大小?
How to limit the file size when uploading with 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 开始检查文件的大小,如果它太大,它将 return false。但是文件仍然刚刚上传。
onFileUploadStart
似乎什么都没做。我试图 console.log
里面的东西,但什么也没有。
我做错了什么? multer上传时如何限制文件大小?
新的multer
API没有onFileUploadStart
。如果您想限制文件大小,您应该将 limits: { fileSize: maxSize }
添加到传递给 multer()
的对象中:
var upload = multer({
storage: storage,
limits: { fileSize: maxSize }
}).single('bestand');
我想是你在看。
祝你有美好的一天。
const fileFilterMiddleware = (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)
}
}
对于通过 Ts.ED 使用 Multer 的任何人。当我试图上传一个太大的文件时(无论它有什么扩展名),我最终出现了以下错误:
Cannot read properties of undefined (reading 'replace')
我确实使用了以下代码来解决这个问题:
@Configuration({
...
multer: {
limits: {
fieldNameSize: 300,
fileSize: 1048576, // 10 Mb
},
fileFilter: (req, file, callback) => {
const acceptableExtensions = ['.png', '.jpg'];
if (!(acceptableExtensions.includes(Path.extname(file.originalname)))) {
return callback(new Error('...'));
}
// added this
const fileSize = parseInt(req.headers['content-length']);
if (fileSize > 1048576) {
return callback(new Error('...'));
}
// --
callback(null, true);
}
}
})
现在可以了。
我正在用 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 开始检查文件的大小,如果它太大,它将 return false。但是文件仍然刚刚上传。
onFileUploadStart
似乎什么都没做。我试图 console.log
里面的东西,但什么也没有。
我做错了什么? multer上传时如何限制文件大小?
新的multer
API没有onFileUploadStart
。如果您想限制文件大小,您应该将 limits: { fileSize: maxSize }
添加到传递给 multer()
的对象中:
var upload = multer({
storage: storage,
limits: { fileSize: maxSize }
}).single('bestand');
我想是你在看。 祝你有美好的一天。
const fileFilterMiddleware = (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)
}
}
对于通过 Ts.ED 使用 Multer 的任何人。当我试图上传一个太大的文件时(无论它有什么扩展名),我最终出现了以下错误:
Cannot read properties of undefined (reading 'replace')
我确实使用了以下代码来解决这个问题:
@Configuration({
...
multer: {
limits: {
fieldNameSize: 300,
fileSize: 1048576, // 10 Mb
},
fileFilter: (req, file, callback) => {
const acceptableExtensions = ['.png', '.jpg'];
if (!(acceptableExtensions.includes(Path.extname(file.originalname)))) {
return callback(new Error('...'));
}
// added this
const fileSize = parseInt(req.headers['content-length']);
if (fileSize > 1048576) {
return callback(new Error('...'));
}
// --
callback(null, true);
}
}
})
现在可以了。