49

我试过Winstonfor logger。我在一个项目中使用了它们,当我将代码从它们复制粘贴到当前现有项目时,它运行良好,而不是遇到类似的问题TypeError: winston.Logger is not a constructor

让 logger = new (winston.Logger)({ ^

TypeError:winston.Logger 不是构造函数

请指导我,为什么会出现这个错误以及我应该怎么做才能解决这个问题。

“摩根”:“^1.9.0”,“温斯顿”:“^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
});
4

1 回答 1

124

正如您所提到的,您正在使用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
});
于 2018-06-28T05:15:40.077 回答