首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >强循环回环自定义错误处理

强循环回环自定义错误处理
EN

Stack Overflow用户
提问于 2017-10-12 06:12:20
回答 1查看 1.8K关注 0票数 1

我目前正在使用环回3.2.1我面临的问题是当访问令牌过期时登录日志文件时未处理的错误。在进行谷歌搜索时,我在这里遇到了这个未处理错误,这里提到我们可以使用自定义错误日志记录中间件。我按照上面提到的指示行事,并将文件提交给它。但是,我得到了以下错误:

错误:无法应用./server/medileware.staging.json:中间件“.中间件/错误记录器”在主配置中未定义“最终”。

当前middleware.staging.json:

代码语言:javascript
复制
...
"final": {
    "loopback#urlNotFound": {}
  },
  "final:after": {
    "./middleware/error-logger": {},
    "strong-error-handler": {
      "params": {
        "debug": false,
        "includeStack": false,
        "log": false
      }
    }
  }

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

代码语言:javascript
复制
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);
  };
}

我在这里错过了什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-10-12 18:50:01

最后,在查看了加载环回的配置文件的代码之后,找到了它。环回当前正在读取所有默认配置文件,然后将它们与env特定文件合并。因此,任何需要进行的配置更改都必须在默认文件中进行,并在env特定文件中设置值,以使更改符合要求。例如,在我的例子中,我试图将中间件添加到middleware.live.json,但没有将它添加到默认的middleware.json文件中。因此,在执行mergePhaseConfig()时,呈现在env特定文件中并在默认文件中搜索的值不存在。在默认文件中添加中间件条目解决了这个问题。文件中已经提到了这一点,但今天却跳过了我的思路。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46702601

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档