-1

我目前正在使用带有 Express 的 bodyParser 来接受 JSON 请求。每当我传入格式不正确的 JSON 对象时,它都会通过端点返回一个令人讨厌的错误,并将其记录到控制台。以下是错误:

SyntaxError: Unexpected string
    at Object.parse (native)
    at parse (/Users/ddibiase-mbp/Documents/Projects/theride_api/node_modules/body-parser/lib/types/json.js:88:17)
    at /Users/ddibiase-mbp/Documents/Projects/theride_api/node_modules/body-parser/lib/read.js:108:18
    at done (/Users/ddibiase-mbp/Documents/Projects/theride_api/node_modules/body-parser/node_modules/raw-body/index.js:239:14)
    at IncomingMessage.onEnd (/Users/ddibiase-mbp/Documents/Projects/theride_api/node_modules/body-parser/node_modules/raw-body/index.js:285:7)
    at IncomingMessage.g (events.js:199:16)
    at IncomingMessage.emit (events.js:104:17)
    at _stream_readable.js:908:16
    at process._tickCallback (node.js:355:11)
SyntaxError: Unexpected string
    at Object.parse (native)
    at parse (/Users/ddibiase-mbp/Documents/Projects/theride_api/node_modules/body-parser/lib/types/json.js:88:17)
    at /Users/ddibiase-mbp/Documents/Projects/theride_api/node_modules/body-parser/lib/read.js:108:18
    at done (/Users/ddibiase-mbp/Documents/Projects/theride_api/node_modules/body-parser/node_modules/raw-body/index.js:239:14)
    at IncomingMessage.onEnd (/Users/ddibiase-mbp/Documents/Projects/theride_api/node_modules/body-parser/node_modules/raw-body/index.js:285:7)
    at IncomingMessage.g (events.js:199:16)
    at IncomingMessage.emit (events.js:104:17)
    at _stream_readable.js:908:16
    at process._tickCallback (node.js:355:11)

我想知道如何抑制错误或完全修补它。我已经调查了该错误,但找不到任何修补它的具体建议。

4

1 回答 1

2

使用 Express声明错误处理程序很常见:

app.use(function(err, req, res, next) {
  ...
  return res.sendStatus(500);
});

这也将捕获中间件中抛出的错误,例如body-parser.

于 2015-08-19T12:47:25.840 回答