国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

Node.js利用console輸出日志文件的方法示例

來源:懂視網 責編:小采 時間:2020-11-27 22:15:46
文檔

Node.js利用console輸出日志文件的方法示例

Node.js利用console輸出日志文件的方法示例:通常我們在寫Node.js程序時,都習慣使用console.log打印日志信息,但這也僅限于控制臺輸出,有時候我們需要將信息輸出到日志文件中,實際上利用console也可以達到這個目的的,今天就來簡單介紹一下。 我們首先創建如下文件: // index.js let
推薦度:
導讀Node.js利用console輸出日志文件的方法示例:通常我們在寫Node.js程序時,都習慣使用console.log打印日志信息,但這也僅限于控制臺輸出,有時候我們需要將信息輸出到日志文件中,實際上利用console也可以達到這個目的的,今天就來簡單介紹一下。 我們首先創建如下文件: // index.js let

通常我們在寫Node.js程序時,都習慣使用console.log打印日志信息,但這也僅限于控制臺輸出,有時候我們需要將信息輸出到日志文件中,實際上利用console也可以達到這個目的的,今天就來簡單介紹一下。

我們首先創建如下文件:

// index.js

let fs = require('fs');

let options = {
 flags: 'a', // append模式
 encoding: 'utf8', // utf8編碼
};

let stdout = fs.createWriteStream('./stdout.log', options);
let stderr = fs.createWriteStream('./stderr.log', options);

// 創建logger
let logger = new console.Console(stdout, stderr);

for (let i = 0; i < 100; i++) {
 logger.log(`log message ${i}`);
 logger.error(`err message ${i}`);
}

在上面代碼中,我們其實是創建了一個console.Console類的實例,該類需要指定兩個參數,即標準輸出流和標準錯誤輸出流,正常情況下,實際上是對應了process.stdout和process.stderr,以上的代碼中,我們將這兩個輸出流改為了文件輸出流,并指定為文件追加模式,這樣即可將日志信息輸出到指定的文件中去。運行上面的代碼,會生成stdout.log和stderr.log兩個文件。

stdout.log文件內容如下:

log message 0
log message 1
log message 2
log message 3
log message 4
log message 5
log message 6
log message 7
log message 8
log message 9
log message 10
...

stderr.log文件內容如下:

err message 0
err message 1
err message 2
err message 3
err message 4
err message 5
err message 6
err message 7
err message 8
err message 9
err message 10
...

看上去信息還比較簡單,不像是日志文件的樣子,我們或許得為每條日志添加一個時間才行,下面先為Date對象添加一個format的原型方法:

// 添加format方法
Date.prototype.format = function (format) {

 if (!format) {
 format = 'yyyy-MM-dd HH:mm:ss';
 }
 
 // 用0補齊指定位數
 let padNum = function (value, digits) {
 return Array(digits - value.toString().length + 1).join('0') + value;
 };

 // 指定格式字符
 let cfg = {
 yyyy: this.getFullYear(), // 年
 MM: padNum(this.getMonth() + 1, 2), // 月
 dd: padNum(this.getDate(), 2), // 日
 HH: padNum(this.getHours(), 2), // 時
 mm: padNum(this.getMinutes(), 2), // 分
 ss: padNum(this.getSeconds(), 2), // 秒
 fff: padNum(this.getMilliseconds(), 3), // 毫秒
 };

 return format.replace(/([a-z]|[A-Z])(\1)*/ig, function (m) {
 return cfg[m];
 });
}

然后再改寫前面的主文件:

// index.js

let fs = require('fs');

let options = {
 flags: 'a', // append模式
 encoding: 'utf8', // utf8編碼
};

let stdout = fs.createWriteStream('./stdout.log', options);
let stderr = fs.createWriteStream('./stderr.log', options);

// 創建logger
let logger = new console.Console(stdout, stderr);

// 添加format方法
Date.prototype.format = function (format) {

 if (!format) {
 format = 'yyyy-MM-dd HH:mm:ss';
 }
 
 // 用0補齊指定位數
 let padNum = function (value, digits) {
 return Array(digits - value.toString().length + 1).join('0') + value;
 };

 // 指定格式字符
 let cfg = {
 yyyy: this.getFullYear(), // 年
 MM: padNum(this.getMonth() + 1, 2), // 月
 dd: padNum(this.getDate(), 2), // 日
 HH: padNum(this.getHours(), 2), // 時
 mm: padNum(this.getMinutes(), 2), // 分
 ss: padNum(this.getSeconds(), 2), // 秒
 fff: padNum(this.getMilliseconds(), 3), // 毫秒
 };

 return format.replace(/([a-z]|[A-Z])(\1)*/ig, function (m) {
 return cfg[m];
 });
}

for (let i = 0; i < 100; i++) {

 let time = new Date().format('yyyy-MM-dd HH:mm:ss.fff');

 logger.log(`[${time}] - log message ${i}`);
 logger.error(`[${time}] - err message ${i}`);
}

重新運行程序,然后查看兩個日志文件的內容。

stdout.log內容如下:

[2018-04-27 07:30:54.309] - log message 0
[2018-04-27 07:30:54.312] - log message 1
[2018-04-27 07:30:54.312] - log message 2
[2018-04-27 07:30:54.312] - log message 3
[2018-04-27 07:30:54.312] - log message 4
[2018-04-27 07:30:54.312] - log message 5
[2018-04-27 07:30:54.312] - log message 6
[2018-04-27 07:30:54.312] - log message 7
[2018-04-27 07:30:54.312] - log message 8
[2018-04-27 07:30:54.312] - log message 9
[2018-04-27 07:30:54.312] - log message 10
...

stderr.log內容如下:

[2018-04-27 07:30:54.309] - err message 0
[2018-04-27 07:30:54.312] - err message 1
[2018-04-27 07:30:54.312] - err message 2
[2018-04-27 07:30:54.312] - err message 3
[2018-04-27 07:30:54.312] - err message 4
[2018-04-27 07:30:54.312] - err message 5
[2018-04-27 07:30:54.312] - err message 6
[2018-04-27 07:30:54.312] - err message 7
[2018-04-27 07:30:54.312] - err message 8
[2018-04-27 07:30:54.312] - err message 9
[2018-04-27 07:30:54.312] - err message 10
...

這樣一個簡單的日志輸出就完成了。

參考資料:https://nodejs.org/api/console.html

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

Node.js利用console輸出日志文件的方法示例

Node.js利用console輸出日志文件的方法示例:通常我們在寫Node.js程序時,都習慣使用console.log打印日志信息,但這也僅限于控制臺輸出,有時候我們需要將信息輸出到日志文件中,實際上利用console也可以達到這個目的的,今天就來簡單介紹一下。 我們首先創建如下文件: // index.js let
推薦度:
標簽: 文件 利用 方法
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 精品国产一区二区 | 国产欧美日韩另类 | 欧美日韩亚洲一区二区三区在线观看 | 国内高清久久久久久久久 | 国产精品1| 97精品国产91久久久久久久 | 欧美日韩综合精品一区二区三区 | 国产高清美女一级a毛片 | 欧美一区二区在线 | 日日天天| 国产精品亚洲片在线观看不卡 | 欧美性一区二区三区五区 | 广州一级毛片 | 国产美女白丝袜精品_a不卡 | 国产视频欧美 | 在线观看国产精品入口 | 亚洲国产成人精彩精品 | 欧美日韩亚洲国产一区二区三区 | 日韩a电影 | 亚洲 欧洲 另类 综合 自拍 | 欧美啊v | 91久久精品国产91久久性色也 | 国产精品网站在线观看 | 国产欧美成人一区二区三区 | 夜夜操网| 亚洲精品国产综合一线久久 | 久久国产精品一区二区 | 亚洲一区有码 | 99在线视频观看 | 日韩欧美爱爱 | 国内精品久久久久影院不卡 | 亚洲va欧美ⅴa国产va影院 | 日韩国产欧美 | 亚洲国产精品日韩一线满 | 香蕉久久一区二区三区 | 91精品国产色综合久久 | 91久久国产情侣真实对白 | 亚洲欧美另类自拍 | 九九国产精品九九 | 日本七十路 | 精品精品国产高清a毛片牛牛 |