Mer*_*erk 17 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);
});
});
Run Code Online (Sandbox Code Playgroud)
一切正常,文件上传.唯一不起作用的是最大尺寸的限制.我这样做是为了让onfileupload启动文件的大小得到检查,如果它变大,它将返回false.但该文件仍然上传.
似乎onFileUploadStart根本没有做任何事情.我尝试了console.log一些东西,但没有.
我究竟做错了什么?使用multer上传时如何限制文件大小?
msc*_*dex 39
onFileUploadStart新的multerAPI 没有.如果要限制文件大小,则应该添加limits: { fileSize: maxSize }到传递给的对象multer():
var upload = multer({
storage: storage,
limits: { fileSize: maxSize }
}).single('bestand');
Run Code Online (Sandbox Code Playgroud)
小智 17
我想这就是你正在寻找的。祝你有美好的一天。
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)
}
}
Run Code Online (Sandbox Code Playgroud)
对于任何使用 Multer 和Ts.ED的人。当我尝试上传太大的文件(无论其扩展名是什么)时,最终出现以下错误:
无法读取未定义的属性(读取“替换”)
我确实使用以下代码来解决此问题:
@Configuration({
...
multer: {
limits: {
fieldNameSize: 300,
fileSize: 1048576, // 1 Mb allowed
},
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);
}
}
})
Run Code Online (Sandbox Code Playgroud)
现在可以了。
| 归档时间: |
|
| 查看次数: |
20931 次 |
| 最近记录: |