[转]c# log4net 配置使用
新增配置文件log4net.config,内容如下
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 | <?xml version= "1.0" encoding= "utf-8" ?> <configuration> <configSections> <section name= "log4net" type= "log4net.Config.Log4NetConfigurationSectionHandler, log4net" /> </configSections> <log4net> <!--新增节点说明: --> <!--1、复制一个appender节点,修改name,修改file,其他内容看情况修改--> <!--2、复制一个logger节点,修改appender- ref 为步骤2中appender的name,修改name(调用WriteByLogType函数,传入的type),--> <appender name= "InfoAppender" type= "log4net.Appender.RollingFileAppender" > <!--保存路径:下面路径项目启动的时候自动在C盘中创建log、logError文件--> <file value= "log\\Info\\" /> <!-- 如果想在本项目中添加路径,那就直接去掉C:\\ 只设置log\\LogError 项目启动中默认创建文件 --> <appendToFile value= "true" /> <!--按照何种方式产生多个日志文件(日期[Date],文件大小[Size],混合[Composite])--> <rollingStyle value= "Composite" /> <!--这是按日期产生文件夹--> <datePattern value= "yyyy-MM\\yyyy-MM-dd'.txt'" /> <!--是否只写到一个文件中--> <staticLogFileName value= "false" /> <!--保留的log文件数量 超过此数量后 自动删除之前的 好像只有在 按Size分割时有效 设定值value= "-1" 为不限文件数--> <param name= "MaxSizeRollBackups" value= "100" /> <!--每个文件的大小。只在混合方式与文件大小方式下使用。超出大小后在所有文件名后自动增加正整数重新命名,数字最大的最早写入。可用的单位:KB|MB|GB。不要使用小数,否则会一直写入当前日志--> <maximumFileSize value= "10240KB" /> <!-- layout 控制Appender的输出格式,也可以是xml 一个Appender只能是一个layout--> <layout type= "log4net.Layout.PatternLayout" > <!--每条日志末尾的文字说明--> <!--输出格式 模板--> <!-- <param name= "ConversionPattern" value="记录时间:%date 线程ID:[%thread] 日志级别:%-5level 记录类:%logger 操作者ID:%property{Operator} 操作类型:%property{Action}%n 当前机器名:%property%n当前机器名及登录用户:%username %n 记录位置:%location%n 消息描述:%property{Message}%n 异常:%exception%n 消息:%message%newline%n%n" />--> <!--样例:2008-03-26 13:42:32,111 [10] INFO Log4NetDemo.MainClass [( null )] - info--> <!--<conversionPattern value= "%newline %n记录时间:%date %n线程ID:[%thread] %n日志级别: %-5level %n错误描述:%message%newline %n" />--> <conversionPattern value="%n========== %n【记录时间】%date %n【记录的类】%logger 属性[%property{NDC}] %n【内容描述】%message"/> </layout> </appender> <appender name= "ErrorAppender" type= "log4net.Appender.RollingFileAppender" > <!--保存路径:下面路径项目启动的时候自动在C盘中创建log、logError文件--> <file value= "log\\Error\\" /> <!-- 如果想在本项目中添加路径,那就直接去掉C:\\ 只设置log\\LogError 项目启动中默认创建文件 --> <appendToFile value= "true" /> <!--按照何种方式产生多个日志文件(日期[Date],文件大小[Size],混合[Composite])--> <rollingStyle value= "Composite" /> <!--这是按日期产生文件夹--> <datePattern value= "yyyy-MM\\yyyy-MM-dd'.txt'" /> <!--是否只写到一个文件中--> <staticLogFileName value= "false" /> <!--保留的log文件数量 超过此数量后 自动删除之前的 好像只有在 按Size分割时有效 设定值value= "-1" 为不限文件数--> <param name= "MaxSizeRollBackups" value= "100" /> <!--每个文件的大小。只在混合方式与文件大小方式下使用。超出大小后在所有文件名后自动增加正整数重新命名,数字最大的最早写入。可用的单位:KB|MB|GB。不要使用小数,否则会一直写入当前日志--> <maximumFileSize value= "10240KB" /> <!-- layout 控制Appender的输出格式,也可以是xml 一个Appender只能是一个layout--> <layout type= "log4net.Layout.PatternLayout" > <!--每条日志末尾的文字说明--> <!--输出格式 模板--> <!-- <param name= "ConversionPattern" value="记录时间:%date 线程ID:[%thread] 日志级别:%-5level 记录类:%logger 操作者ID:%property{Operator} 操作类型:%property{Action}%n 当前机器名:%property%n当前机器名及登录用户:%username %n 记录位置:%location%n 消息描述:%property{Message}%n 异常:%exception%n 消息:%message%newline%n%n" />--> <!--样例:2008-03-26 13:42:32,111 [10] INFO Log4NetDemo.MainClass [( null )] - info--> <!--<conversionPattern value= "%newline %n记录时间:%date %n线程ID:[%thread] %n日志级别: %-5level %n错误描述:%message%newline %n" />--> <conversionPattern value="%n========== %n【日志级别】%-5level %n【记录时间】%date %n【线程编号】[%thread] %n【执行时间】[%r]毫秒 %n【出错文件】%F %n【出错行号】%L %n【出错的类】%logger 属性[%property{NDC}] %n【错误描述】%message %n【错误详情】%newline"/> </layout> </appender> <logger name= "info_logo" > <level value= "ALL" /> <appender- ref ref = "InfoAppender" /> </logger> <logger name= "error_logo" > <level value= "ALL" /> <appender- ref ref = "ErrorAppender" /> </logger> </log4net> </configuration> |
写个帮助类
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 | public class Log4NetHelper { private static string m_logFile; private static Dictionary< string , log4net.ILog> m_lstLog = new Dictionary< string , log4net.ILog>(); public static void InitLog4Net( string strLog4NetConfigFile) { log4net.Config.XmlConfigurator.Configure( new System.IO.FileInfo(strLog4NetConfigFile)); m_logFile = strLog4NetConfigFile; m_lstLog[ "info_logo" ] = log4net.LogManager.GetLogger( "info_logo" ); m_lstLog[ "error_logo" ] = log4net.LogManager.GetLogger( "error_logo" ); } /// <summary> /// 功能描述:写入常规日志 /// </summary> /// <param name="strInfoLog">strInfoLog</param> public static void WriteInfoLog( string strInfoLog) { if (m_lstLog[ "info_logo" ].IsInfoEnabled) { m_lstLog[ "info_logo" ].Info(strInfoLog); } } /// <summary> /// 功能描述:写入错误日志 /// </summary> /// <param name="strErrLog">strErrLog</param> /// <param name="ex">ex</param> public static void WriteErrorLog( string strErrLog, Exception ex = null ) { if (m_lstLog[ "error_logo" ].IsErrorEnabled) { m_lstLog[ "error_logo" ].Error(strErrLog, ex); } } /// <summary> /// 功能描述:写入日志 /// </summary> /// <param name="strType">日志类型(对应log4net配置文件中logger.nama)</param> /// <param name="strLog">strLog</param> public static void WriteByLogType( string strType, string strLog) { if (!m_lstLog.ContainsKey(strType)) { //判断是否存在节点 if (!HasLogNode(strType)) { WriteErrorLog( "log4net配置文件不存在【" + strType + "】配置" ); return ; } m_lstLog[strType] = log4net.LogManager.GetLogger(strType); } m_lstLog[strType].Error(strLog); } /// <summary> /// 功能描述:是否存在指定的配置 /// </summary> /// <param name="strNodeName">strNodeName</param> /// <returns>返回值</returns> private static bool HasLogNode( string strNodeName) { XmlDocument doc = new XmlDocument(); doc.Load(m_logFile); var lstNodes = doc.SelectNodes( "//configuration/log4net/logger" ); foreach (XmlNode item in lstNodes) { if (item.Attributes[ "name" ].Value.ToLower() == strNodeName) return true ; } return false ; } } |
程序启动时初始化
Log4NetHelper.InitLog4Net(Application.StartupPath + "\\log4net.config");
需要的地方调用函数写日志就可以了
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现