strongloop loopback自定义错误处理

时间:2017-10-12 06:12:20

标签: node.js logging strongloop loopback

我目前正在使用环回3.2.1我面临的问题是在访问令牌过期时未记录的错误登录日志文件。进行谷歌搜索我遇到了这个Unhandled error这里提到我们可以有自定义错误记录中间件。我按照那里提到的说明进行了操作,并为此提交了文件。但是我收到以下错误:

错误:无法应用... / server / middleware.staging.json:中间件" ./ middleware / error-logger"在阶段" final:在"之后未在主配置中定义。

当前的middleware.staging.json:

...
"final": {
    "loopback#urlNotFound": {}
  },
  "final:after": {
    "./middleware/error-logger": {},
    "strong-error-handler": {
      "params": {
        "debug": false,
        "includeStack": false,
        "log": false
      }
    }
  }

服务器/中间件/错误logger.js:

module.exports = function createErrorLogger(options) {
  return function logError(err, req, res, next) {
    // your custom error-logging logic goes here

    const status = err.status || err.statusCode;
    if (status >= 500) {
      // log only Internal Server errors
      console.log('Unhandled error for request %s %s: %s',
        req.method, req.url, err.stack || err);
    }

    // Let the next error handler middleware
    // produce the HTTP response
    next(err);
  };
}

我在这里缺少什么?

1 个答案:

答案 0 :(得分:1)

最后看了加载loopback配置文件的代码后想出来了。 Loopback当前正在读取所有默认配置文件,然后将它们与env特定文件合并。因此,必须在默认文件中进行任何需要进行的配置更改,并在env特定文件中设置值,以使更改按要求运行。例如,在我的情况下,我试图将中间件添加到middleware.live.json,但没有将其添加到默认的middleware.json文件中。因此,在执行 mergePhaseConfig()时,env特定文件中存在的值并在默认文件中搜索,该文件不存在。 在默认文件中添加中间件条目解决了该问题。这已经在文件中提到过了,但今天我忽略了。