1

我正在处理一个带有 node.js 后端的新项目,我的morgan记录器工作得非常好。tiny起初,我无法使用任何预定义的摩根模板( 、、等)从中获取任何输出,short没有任何东西传播到输出。我提供了自定义日志记录功能来验证 morgan 在我的堆栈上是否被调用:

app.use(morgan((tokens, req, res) => {
console.log('AAAAAAAAAAA');
return 'ABABABABABAA';
}, { stream: process.stdout }));

序列AAAAAAAAAAA确实通过colsole.log内部日志功能传播到控制台输出(证明 morga 在每个请求上实际调用),但日志功能根本不提供它的ABABABABABA序列。

只要我能够想象预定义的格式可能由于req/res对象的非常规名称而失败(顺便说一句,这不是一种情况),那么从 logger 函数返回的纯文本显然应该直接传播到输出。

编辑

将 morgan 选项设置为{immediate: true}也不能解决问题。

4

1 回答 1

9

就我而言,问题在于我没有在创建应用程序后立即调用“摩根”。当我改变它的位置时,它解决了这个问题。我在“摩根”页面中找不到任何关于此的参考,但我在这里的另一个答案中找到了它:Express Morgan not writing logs to file or STDOUT

工作解决方案:

let app = express()
app.use(morgan('combined'))     <--- morgan right after app
app.set('views', './views')
app.set('view engine', 'ejs')
app.use('/', routes)

不工作的代码(以前):

let app = express()
app.set('views', './views')
app.set('view engine', 'ejs')
app.use('/', routes)
app.use(morgan('combined'))     <--- morgan
于 2019-03-18T02:24:07.940 回答