(自用)MyLog 简单日志 .net6.0 等

appsettings.json

cs 复制代码
{
  "LogOnOff": true //true 开启日志;false 关闭日志
}

MyLog.cs

cs 复制代码
using System.ComponentModel;

namespace Namespace 
{
    /// <summary>
    /// 日志类型 枚举
    /// </summary>
    public enum LogType
    {
        [Description("调试日志")]
        debug,//日常调试信息
        //[Description("警告日志")]
        //warning,//有错但是程序能继续执行
        [Description("报错日志")]
        error,//有错程序抛出异常
    }

    /// <summary>
    /// 创建日志文件夹
    /// 创建日志文件
    /// 写入日志内容
    /// </summary>
    public class MyLog
    {
        public static bool LogOnOff = Tools.ToBool(CustomConfigManager.GetConfig("LogOnOff"), false);//日志开关,配置在config文件

        /// <summary>
        /// 写日志
        /// </summary>
        /// <param name="log">日志(必填)</param>
        /// <param name="ex">报错信息(选填)</param>
        /// <param name="LogType">日志类型(默认:debug)</param>
        public static void WriteLog(string log, string ex = "", LogType logType = LogType.debug)
        {
            if (LogOnOff == true)//日志开关,配置在config文件
            {
                try
                {
                    string path = "log/" + logType;//文件夹路径:log/info   或者  log/error   这样的...
                    string file = path + "/" + logType + "_" + DateTime.Today.ToString("yyyyMMdd") + ".log";//文件路径+文件名+扩展名
                    if (!Directory.Exists(path))//判断文件夹是否存在
                    {
                        Directory.CreateDirectory(path);//不存在,创建文件夹
                    }
                    if (logType == LogType.error)//报错日志(一般文件比较大可能几个G,往往打不开),所以error以分钟为单位创建文件(拆分成多个小文件)
                    {
                        file = path + "/" + logType + "_" + DateTime.Today.ToString("yyyyMMddHHmm") + ".log";//文件路径+文件名+扩展名
                    }
                    using (StreamWriter sw = new StreamWriter(file, true))//创建文件或者打开已有文件
                    {
                        sw.WriteLine("------------------------------" + DateTime.Now + "------------------------------");
                        if (!string.IsNullOrWhiteSpace(log)) sw.WriteLine(log);//写入日志
                        if (!string.IsNullOrWhiteSpace(ex)) sw.WriteLine(ex);//写入报错信息(如果需要的话)
                        sw.WriteLine("");//空一行
                        sw.Close();
                    }
                }
                catch { }
            }
        }
    }
}

调用:

MyLog.WriteLog("正在启动监听服务...");//debug日志

MyLog.WriteLog($"报错: {ex.Message}", ex.ToString(), LogType.error);//error日志


预览:

相关推荐
Evand J8 分钟前
【论文复现】MATLAB例程,存在测距误差的WSN无锚点分布式自定位,《WSN中存在测距误差的无锚点分布式自定位方法》
开发语言·分布式·matlab·定位·导航·wsn
techdashen26 分钟前
kTLS 进入 rustls 组织:把 TLS 的数据面交给内核
开发语言·php
Lhappy嘻嘻42 分钟前
Java 并发编程(六)|并发进阶高频:CAS、锁升级
java·开发语言
techdashen1 小时前
Arborium:把 tree-sitter 语法高亮打包成 Rust 文档生态的基础设施
开发语言·后端·rust
会周易的程序员1 小时前
microLog 后端开发指南
开发语言·c++·物联网·设计模式·日志·iot·aiot
Esaka_Forever1 小时前
Python 完整内存管理机制详解
开发语言·python·spring
星空露珠1 小时前
迷你世界UGc3.0脚本Wiki[剧情动画模块管理接口 Timeline]
开发语言·数据结构·算法·游戏·lua
未来之窗软件服务1 小时前
计算机考试-C语言 应用题—东方仙盟
c语言·开发语言·仙盟创梦ide·东方仙盟·计算机考试
想你依然心痛1 小时前
AtomCode在后端开发中的实战体验:Go微服务从零搭建
开发语言·微服务·golang
我是一颗柠檬2 小时前
【Java项目技术亮点】EXPLAIN深度分析与慢查询治理
android·java·开发语言