温斯顿/Node.js如何仅为特定路线添加传输?



假设我有以下 API 及其各自的路由,如下所示 -

1(/api/v1/teachers - 用于教师的 CRUD 操作

2(/api/v1/students - 用于学生的 CRUD 操作

目前,我将两个 API 请求的日志存储在组合.log文件中。我想在教师.log文件中存储教师的CRUD操作日志,并在学生.log文件中存储学生的CRUD操作日志。

我提到了以下问题,其中作者希望根据特定环境存储某些日志。

温斯顿/节点.js如何仅为特定环境添加传输?

const winston = require('winston');
const transports = [
new winston.transports.Console({
level    : 'info',
colorize : true
}),
new winston.transports.File({
level    : 'info',
filename : './logs/logs.log'
})
];
if (process.env.NODE_ENV === 'production') {
const Mail = require('winston-mail').Mail;
transports.push(new Mail({
to       : 'xxxxxx@xxxxxx.xx',
from     : 'winston@xxxxx.xx',
subject  : 'Errors occurred',
level    : 'error',
host     : 'smtp.xxxxx.xx',
username : 'xxxx@xxxx.xx', 
password : 'xxxxx',
port     : 1234
}));
}
const logger = new winston.Logger({
transports
});

但是由于我无法访问 winston 中的请求对象本身.js因此我无法应用基于路由的条件将不同路由的日志存储在不同的文件中。

您可以创建 2 个传输,并使用 express-winston 在路由器之前选择指定的传输。

var router = require('./teachers-router');
app.use(expressWinston.logger({
transports: [
new winston.transports.teachers, // you will need to create this one by your own
],
}));
app.use(router); 

最新更新