为了账号安全,请及时绑定邮箱和手机立即绑定

节点:登录文件而不是控制台

节点:登录文件而不是控制台

慕婉清6462132 2019-12-10 10:33:00
我可以配置console.log成将日志写在文件上而不是在控制台上打印吗?
查看完整描述

3 回答

?
守着一只汪

TA贡献1872条经验 获得超3个赞

您也可以只重载默认的console.log函数:


var fs = require('fs');

var util = require('util');

var log_file = fs.createWriteStream(__dirname + '/debug.log', {flags : 'w'});

var log_stdout = process.stdout;


console.log = function(d) { //

  log_file.write(util.format(d) + '\n');

  log_stdout.write(util.format(d) + '\n');

};

上面的示例将日志记录到debug.log和stdout。


查看完整回答
反对 回复 2019-12-10
?
弑天下

TA贡献1818条经验 获得超8个赞

我经常对console.log()和console.error()使用很多参数,所以我的解决方案是:


var fs = require('fs');

var util = require('util');

var logFile = fs.createWriteStream('log.txt', { flags: 'a' });

  // Or 'w' to truncate the file every time the process starts.

var logStdout = process.stdout;


console.log = function () {

  logFile.write(util.format.apply(null, arguments) + '\n');

  logStdout.write(util.format.apply(null, arguments) + '\n');

}

console.error = console.log;


查看完整回答
反对 回复 2019-12-10
  • 3 回答
  • 0 关注
  • 541 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信