Как импортировать зависимость NodeJS winston-daily-rotate-file?

Я могу использовать зависимость winston-daily-rotate-file, используя require.

var DailyRotateFile = require('winston-daily-rotate-file');

Но когда я пытаюсь импортировать, как показано ниже, это не работает. Как это решить?

import * as DailyRotateFile from 'winston-daily-rotate-file';

обычай-logger.js

import { createLogger, format, transports } from 'winston';
import * as DailyRotateFile from 'winston-daily-rotate-file';
import fs from 'fs';
import path from 'path';

const env = process.env.NODE_ENV || 'development';
const logDir = 'log';
if(!fs.existsSync(logDir)) {
    fs.mkdirSync(logDir);
}

const dailyRotateFileTransport = new DailyRotateFile({
    filename: `${logDir}/%DATE%-results.log`,
    datePattern: 'YYYY-MM-DD',
    maxSize: '1k'
})

const logger = createLogger({
    level: env === 'development' ? 'debug' : 'info',
    format: format.combine(
        format.label({ label: path.basename(process.mainModule.filename)}),
        //format.colorize(),
        format.timestamp({
            format: 'YYYY-MM-DD HH:mm:ss'
        }),
        format.json()
    ),
    transports: [
        new transports.Console({
            level: 'info',
            format: format.combine(
                format.printf(
                    info => `${info.timestamp} ${info.level} [${info.label}]: ${info.message}`
                )
            )
        }),
        dailyRotateFileTransport
    ]
});

module.exports = logger;

При запуске приложения получаю следующую ошибку

var dailyRotateFileTransport = new DailyRotateFile({
                               ^

TypeError: DailyRotateFile is not a constructor


person Alexpandiyan Chokkan    schedule 06.06.2019    source источник
comment
Какую именно ошибку вы получаете?   -  person Dzhuneyt    schedule 06.06.2019
comment
@ Джунейт, у меня есть содержимое с ошибкой вместе с файлом пользовательского регистратора.   -  person Alexpandiyan Chokkan    schedule 06.06.2019
comment
Попробуйте заменить import * as DailyRotateFile from 'winston-daily-rotate-file'; на require('winston-daily-rotate-file')   -  person Avanthika    schedule 06.06.2019
comment
github.com/winstonjs/winston-daily-rotate-file/issues/ 90 - Взгляните на это.   -  person Avanthika    schedule 06.06.2019
comment
@Avanthika Я сделал это раньше. Он отлично работает, когда я использую require. Я хотел бы использовать импорт.   -  person Alexpandiyan Chokkan    schedule 06.06.2019
comment
stackoverflow.com/questions/29596714/   -  person Dzhuneyt    schedule 07.06.2019
comment
Разве мы не можем импортировать зависимость winston-daily-rotate-file? Если да, есть ли какая-либо другая последняя доступная зависимость?   -  person Alexpandiyan Chokkan    schedule 07.06.2019


Ответы (3)


import * as winston from 'winston';
import 'winston-daily-rotate-file';
import appRoot from 'app-root-path';


const logger = winston.createLogger({
    transports: [
        new winston.transports.DailyRotateFile ({
            filename: 'application-%DATE%.log',
            dirname: `${appRoot}/logs/`,
            level: 'info',
            handleExceptions: true,
            colorize: true,
            json: false,
            zippedArchive: true,
            maxSize: '20m',
            maxFiles: '14d'        
        })
    ],
    exitOnError: false
});

logger.stream = {
    write: function(message, encoding) {
      logger.info(message);
    },
  };

export default logger;

Это настраивает регистратор для ежедневной ротации.

person user12575927    schedule 19.04.2020
comment
Хорошо работай для меня. Спасибо - person Alexander Vu; 21.04.2021
comment
PR для этого в настоящее время открыт здесь как для es6, так и для машинописного текста github.com /winstonjs/winston-daily-rotate-file/pull/320 - person user12575927; 12.06.2021

Попробуй это:

import WinstonDailyRotate from "winston-daily-rotate-file";

const daily_rotate_transport = new WinstonDailyRotate({
  filename: "./logs/app",
  datePattern: "YYYY-MM/DD[.log]",
});
person Talha dogar    schedule 26.10.2020

попробуй это

import DailyRotateFile = require("winston-daily-rotate-file");

person ondaa P    schedule 20.09.2019
comment
ты пробовал? - person Lawrence Cherone; 20.09.2019