TypeError: winston.Logger не является конструктором с winston и morgan
Я попробовал с Winston
для logger
. Я использовал в одном проекте их работу. Хорошо работает, когда я копирую код из своего текущего существующего проекта, чем я сталкиваюсь с проблемой типа TypeError: winston.Logger is not a constructor
пусть logger = new (winston.Logger) ({^
TypeError: winston.Logger не является конструктором
Пожалуйста, помогите мне, почему эта ошибка и что мне нужно сделать для решения этой проблемы.
"morgan": "^ 1.9.0", "winston": "^ 3.0.0"
Ниже приведен мой код в файле logger.js
.
var appRoot = require('app-root-path');
var winston = require('winston');
var options = {
file: {
level: 'info',
name: 'file.info',
filename: '${appRoot}/logs/app.log',
handleExceptions: true,
json: true,
maxsize: 5242880, // 5MB
maxFiles: 100,
colorize: true,
},
errorFile: {
level: 'error',
name: 'file.error',
filename: '${appRoot}/logs/error.log',
handleExceptions: true,
json: true,
maxsize: 5242880, // 5MB
maxFiles: 100,
colorize: true,
},
console: {
level: 'debug',
handleExceptions: true,
json: false,
colorize: true,
},
};
// your centralized logger object
let logger = new (winston.Logger)({
transports: [
new (winston.transports.Console)(options.console),
new (winston.transports.File)(options.errorFile),
new (winston.transports.File)(options.file)
],
exitOnError: false, // do not exit on handled exceptions
});
Ответы
Ответ 1
Как вы говорите, вы используете 3.0.0
, вы не можете использовать winston.Logger
, вы можете ссылаться на код библиотеки (https://github.com/winstonjs/winston/blob/master/lib/winston.js#L178)
Вы должны сделать небольшое обновление в своем коде, используйте winston.createLogger
вместо new (winston.Logger)
// your centralized logger object
let logger = winston.createLogger({
transports: [
new (winston.transports.Console)(options.console),
new (winston.transports.File)(options.errorFile),
new (winston.transports.File)(options.file)
],
exitOnError: false, // do not exit on handled exceptions
});