gpt4 book ai didi

node.js - winston 记录器文件名错误未定义

转载 作者:搜寻专家 更新时间:2023-10-31 23:08:37 39 4
gpt4 key购买 nike

我是 node js 的新手,正在尝试为我的项目使用 winston logger,一切正常,但是当我尝试创建自己的记录器对象并将日志传输到文件名时,出现错误:TypeError:无法读取未定义的属性“文件名”我觉得我做了任何愚蠢的事情,因为当我只是尝试使用 winston 默认对象将日志写入文件时它起作用了,我正在发布我的代码和错误快照。

我创建了简单的 express js 项目,并在 app.js 中编写了如下日志代码:

/**
* Module dependencies.
*/

var express = require('express'), routes = require('./routes'), user = require('./routes/user'), http = require('http'), path = require('path');

var app = express();

// all environments
app.set('port', process.env.PORT || 3000);
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));

// development only
if ('development' == app.get('env')) {
app.use(express.errorHandler());
}

app.get('/', routes.index);
app.get('/users', user.list);

// adding winston logger code--------------------
var winston = require('winston');
/*
* winston.add(winston.transports.File, { filename: 'winstonLogs.log' });
*
* winston.log('info', 'Hello distributed log files!'); winston.info('Hello
* again distributed logs');
*
* winston.level = 'debug'; winston.log('debug', 'Now my debug messages are
* written to console!');
*
* //winston.remove(winston.transports.Console);
*/
// ******************************************************************************


var logger = new (winston.Logger)({
transports: [
new (winston.transports.File)({
name: 'info-file',
filename: 'filelog-info.log',
level: 'info'
}),
new (winston.transports.File)({
name: 'error-file',
filename: 'filelog-error.log',
level: 'error'
})
]
});
logger.add(winston.transports.File);


logger.log('info', 'Hello distributed log files!');
logger.info('Hello again distributed logs');

//logger.add(winston.transports.File).remove(winston.transports.Console);

// ending winston logger code--------------------

http.createServer(app).listen(app.get('port'), function() {
console.log('Express server listening on port ' + app.get('port'));
});

我注释掉的代码正在运行。 enter image description here

提前致谢。

最佳答案

实际上我添加了不应该存在的行。

logger.add(winston.transports.File);

删除它后它开始正常工作......

关于node.js - winston 记录器文件名错误未定义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34350326/

39 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com