Nodejs Express Multer 文件过大错误处理

8
我正在使用ExpressJS中的multer。我希望限制文件上传大小为0.5MB。
var limits = { fileSize: 0.5 * 1024 * 1024 };

var upload = multer({ dest: './public/uploads/', limits: limits
 }).single('upl')

 app.post('/',upload, function (req, res) {
  upload(req, res, function (err) {
    if (err) {
            console.log("cs " + err);
      return
    }

           res.end('You new avatar is uploaded')
    // Everything went fine
  })
})

当文件大小小于0.5MB时,我能看到“您的新头像已上传”;但当文件大小超过限制时,会出现以下提示:
Error: File too large
   at makeError (C:\Users\Owner\Desktop\nodejs projects\dummy\node_modules\multer\lib\make-error.js:12:13)
   at abortWithCode (C:\Users\Owner\Desktop\nodejs projects\dummy\node_modules\multer\lib\make-middleware.js:77:22)
   at FileStream.<anonymous> (C:\Users\Owner\Desktop\nodejs projects\dummy\node_modules\multer\lib\make-middleware.js:139:11)
   at emitNone (events.js:80:13)
   at FileStream.emit (events.js:179:7)
   at PartStream.onData (C:\Users\Owner\Desktop\nodejs projects\dummy\node_modules\busboy\lib\types\multipart.js:220:18)
   at emitOne (events.js:90:13)
   at PartStream.emit (events.js:182:7)
   at readableAddChunk (_stream_readable.js:153:18)
   at PartStream.Readable.push (_stream_readable.js:111:10)

显然,我不希望最终用户看到这个。我该如何妥善处理?

那个错误被返回到浏览器了吗?我很惊讶。 - Robert Moskal
2个回答

11

试着这样改写(先移除“上传”):

app.post('/', function (req, res) {
  upload(req, res, function (err) {
    if (err) {
        console.log("cs " + err);
      return
    }

    res.end('You new avatar is uploaded')
    // Everything went fine
  })

那么我该如何引入大小限制呢? - sssaini
在app.post('/')中,写下您的代码,就像删除上传中间件一样。 - KibGzr

1

我在server.js文件的末尾创建了一个Express处理程序。

  1. 将处理函数放置在所有app.use()之后,检查这个错误是否来自multer并发送您所需的数据。我的代码发送LIMIT_FILE_SIZE字符串。
app.use(() => (err: Error, req: Request, res: Response, next: NextFunction) => {
    if (err instanceof multer.MulterError) {
        return res.status(418).send(err.code);
    }
});

文档:http://expressjs.com/zh-cn/guide/error-handling.html#error-handling


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接