@hutechwebsite/debitis-excepturi-reprehenderit-inventore
v1.0.0
Published
[![npm version](https://badge.fury.io/js/@hutechwebsite/debitis-excepturi-reprehenderit-inventore.svg)](https://badge.fury.io/js/@hutechwebsite/debitis-excepturi-reprehenderit-inventore)
Downloads
2
Maintainers
Keywords
Readme
@hutechwebsite/debitis-excepturi-reprehenderit-inventore
@hutechwebsite/debitis-excepturi-reprehenderit-inventore是一个用于记录日志、统一日志格式并优化输出的npm包,基于nodejs可写流异步写入log至文件,提供了一系列的接口,用于在控制台和文件中打印日志。同时,还提供了一些工具函数,用于格式化日志信息、加密敏感内容、为不同类型及不同关键词上色等等。
安装
使用npm进行安装:
npm install @hutechwebsite/debitis-excepturi-reprehenderit-inventore
使用示例
使用@hutechwebsite/debitis-excepturi-reprehenderit-inventore非常简单,首先导入@hutechwebsite/debitis-excepturi-reprehenderit-inventore:
const Rlog = require("@hutechwebsite/debitis-excepturi-reprehenderit-inventore");
然后创建一个Rlog实例:
const rlog = new Rlog();
接下来就可以使用各种接口来输出日志了。
具体来说,./test.js
中有大量对rlog的调用示例,以供查看。
一个最简单的使用示例如下:
const Rlog = require("@hutechwebsite/debitis-excepturi-reprehenderit-inventore");
const rlog = new Rlog({
enableColorfulOutput: true,
logFilePath: "logs.txt",
});
rlog.config.setConfig({
timeFormat: "YYYY-MM-DD HH:mm:ss",
timezone: "Asia/Shanghai",
blockedWordsList: ["password", "secret"],
});
rlog.info("This is an information log");
rlog.log("This is an automatically recognized type of log output");
rlog.warning("This is a warning log");
rlog.error("This is an error log");
rlog.success("This is a success log");
rlog.exit("This is a secure exit method");
接口
Rlog
rlog.methodName();
Rlog是@hutechwebsite/debitis-excepturi-reprehenderit-inventore的主类,用于创建日志实例,会自动调用File和Screen方法。它具有以下方法:
info(message)
:打印一条信息日志,并将其写入日志文件。warning(message)
:打印一条警告日志,并将其写入日志文件。error(message)
:打印一条错误日志,并将其写入日志文件。success(message)
:打印一条成功日志,并将其写入日志文件。exit(message)
:打印一条退出日志,并将其写入日志文件,然后终止应用程序。log(message)
: 自动识别message类型并调用相关函数。
Config
rlog.config;
Config是一个用于配置@hutechwebsite/debitis-excepturi-reprehenderit-inventore的类。可设置的项,详见#配置。
enableColorfulOutput
(boolean):是否启用彩色输出,默认为true。logFilePath
(string):日志文件的路径,默认为undefined,表示不将日志写入文件。timeFormat
(string):时间的格式,默认为"YYYY-MM-DD HH:mm:ss.SSS"。timezone
(string):时区,默认为"GMT"。blockedWordsList
(Array<string>):需要屏蔽的敏感词列表,默认为空数组。customColorRules
(Array<{reg: string, color: string}>):自定义的颜色规则列表,默认包含一些常用规则。
Config类提供了以下方法:
setConfig(obj)
:根据传入的对象更新配置。setConfigGlobal(obj)
:根据传入的对象更新配置,并将更新后的配置应用到全局。
Toolkit
rlog.toolkit.methodName();
Toolkit是一个工具类,用于提供一些常用的工具函数。它具有以下方法:
checkLogFile(path)
:检查日志文件是否存在,如果不存在则创建该文件。colorizeString(str)
:根据配置的颜色规则对字符串进行着色。formatTime()
:根据配置的时间格式和时区生成时间字符串。encryptPrivacyContent(str)
:对字符串中的敏感内容进行加密。colorizeType(variable)
:根据变量的类型对其进行着色。padLines(str, width)
:对字符串中除第一行外的每一行进行缩进。
Screen
rlog.screen.methodName();
Screen是用于在控制台打印日志的类。调用此方法,将仅在屏幕中输出,不会写入至文件。它具有以下方法:
info(message, time)
:打印一条信息日志。warning(message, time)
:打印一条警告日志。error(message, time)
:打印一条错误日志。success(message, time)
:打印一条成功日志。exit(message, time)
:打印一条退出日志,并终止应用程序。
File
rlog.file.methodName();
File是用于将日志写入文件的类。调用此方法,若已设置日志文件路径,将会写入至文件,不会在屏幕输出。它具有以下方法:
init()
:初始化日志文件,如果配置了日志文件路径。不需要手动调用。writeLogToStream(text)
:将日志写入文件流。writeLog(text)
:将日志写入文件。info(message, time)
:写入一条信息日志。warning(message, time)
:写入一条警告日志。error(message, time)
:写入一条错误日志。success(message, time)
:写入一条成功日志。exit(message, time)
:写入一条退出日志,并终止应用程序。
回调
@hutechwebsite/debitis-excepturi-reprehenderit-inventore提供了一个回调onExit
,用来在退出程序之前执行(如显示issue report提示等)
rlog.onExit(() => {
console.log('rlog.exit() called and event triggered.');
});
配置
@hutechwebsite/debitis-excepturi-reprehenderit-inventore还提供了一些配置选项,可以在创建Rlog实例时进行配置,也可以使用setConfig()
和setConfigGlobal()
或者以rlog.config[config] = <value>
的方式设置。
以下是可用的配置选项及其默认值:
{
enableColorfulOutput: true,
// 是否启用彩色输出
logFilePath: undefined,
// 日志文件路径,如果不设置则不会输出到文件
timeFormat: "YYYY-MM-DD HH:mm:ss.SSS",
// 时间格式
timezone: "GMT",
// 时区
blockedWordsList: [],
// 需要屏蔽的词汇列表
customColorRules: [// 自定义颜色规则
{
reg: "false",
color: "red",
},
{
reg: "true",
color: "green",
},
{
reg: "((2(5[0-5]|[0-4]\\d))|[0-1]?\\d{1,2})(\\.((2(5[0-5]|[0-4]\\d))|[0-1]?\\d{1,2})){3}",
color: "cyan",
},
{
reg: "[a-zA-z]+://[^\\s]*",
color: "cyan",
},
{
reg: "\\d{4}-\\d{1,2}-\\d{1,2}",
color: "green",
},
{
reg: "\\w+([-+.]\\w+)*@\\w+([-.]\\w+)*\\.\\w+([-.]\\w+)*",
color: "cyan",
},
{
reg: "[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}",
color: "cyan",
},
{
reg: "(w+)s*:s*([^;]+)",
color: "cyan",
},
]
}
可以通过传递一个配置对象来配置Rlog实例:
const config = {
enableColorfulOutput: true,
logFilePath: "/path/to/logfile.log",
timeFormat: "YYYY-MM-DD HH:mm:ss.SSS",
timezone: "GMT",
blockedWordsList: ["password", "secret"],
customColorRules: [
{
reg: "error",
color: "red",
},
{
reg: "warning",
color: "yellow",
},
{
reg: "success",
color: "green",
},
],
};
const rlog = new Rlog(config);
或者使用相关函数设置:
rlog.config.setConfig({
timeFormat: "YYYY-MM-DD HH:mm:ss",
timezone: "Asia/Shanghai",
blockedWordsList: ["password", "secret"],
});
rlog.config.setConfigGlobal({
timeFormat: "YYYY-MM-DD HH:mm:ss",
timezone: "Asia/Shanghai",
blockedWordsList: ["password", "secret"],
});
License
MIT License