strongloop 环回自定义错误处理
strongloop loopback custom error handling
我目前正在使用 loopback 3.2.1 我面临的问题是访问令牌过期时记录在日志文件中的未处理错误。在进行 google 搜索时,我遇到了这个 Unhandled error 这里提到我们可以拥有自定义错误记录中间件。我按照那里提到的说明进行操作,并为此参考了文档。但是我收到以下错误:
错误:无法应用.../server/middleware。staging.json:阶段 "final:after" 中的中间件“./middleware/error-logger”未在主配置中定义。
当前中间件。staging.json:
...
"final": {
"loopback#urlNotFound": {}
},
"final:after": {
"./middleware/error-logger": {},
"strong-error-handler": {
"params": {
"debug": false,
"includeStack": false,
"log": false
}
}
}
服务器/middleware/error-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);
};
}
我在这里错过了什么?
在查看加载环回配置文件的代码后,终于弄明白了。 Loopback 当前正在读取所有默认配置文件,然后将它们与 env 特定文件合并。因此,任何需要进行的配置更改都必须在默认文件中进行,并在环境特定文件中设置值,以使更改按要求运行。例如,在我的例子中,我试图将中间件添加到 middleware.live.json 但没有将它添加到默认的 middleware.json 文件。因此,在执行 mergePhaseConfig() 时,环境特定文件中存在的值并在不存在的默认文件中搜索。
在默认文件中添加中间件条目解决了这个问题。文档中已经提到了这一点,但我今天没有想到。
我目前正在使用 loopback 3.2.1 我面临的问题是访问令牌过期时记录在日志文件中的未处理错误。在进行 google 搜索时,我遇到了这个 Unhandled error 这里提到我们可以拥有自定义错误记录中间件。我按照那里提到的说明进行操作,并为此参考了文档。但是我收到以下错误:
错误:无法应用.../server/middleware。staging.json:阶段 "final:after" 中的中间件“./middleware/error-logger”未在主配置中定义。
当前中间件。staging.json:
...
"final": {
"loopback#urlNotFound": {}
},
"final:after": {
"./middleware/error-logger": {},
"strong-error-handler": {
"params": {
"debug": false,
"includeStack": false,
"log": false
}
}
}
服务器/middleware/error-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);
};
}
我在这里错过了什么?
在查看加载环回配置文件的代码后,终于弄明白了。 Loopback 当前正在读取所有默认配置文件,然后将它们与 env 特定文件合并。因此,任何需要进行的配置更改都必须在默认文件中进行,并在环境特定文件中设置值,以使更改按要求运行。例如,在我的例子中,我试图将中间件添加到 middleware.live.json 但没有将它添加到默认的 middleware.json 文件。因此,在执行 mergePhaseConfig() 时,环境特定文件中存在的值并在不存在的默认文件中搜索。 在默认文件中添加中间件条目解决了这个问题。文档中已经提到了这一点,但我今天没有想到。