網站首頁 編程語言 正文
一、Config文件配置
<?xml version="1.0" encoding="utf-8" ?> <configuration> <configSections> <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler"/> </configSections> <!-- Level的級別,由高到低 --> <!-- None > Fatal > ERROR > WARN > DEBUG > INFO > ALL--> <!-- 解釋:如果level是ERROR,則在cs文件里面調用log4net的info()方法,則不會寫入到日志文件中--> <log4net> <!--錯誤日志類--> <logger name="logerror"> <!--日志類的名字--> <level value="ALL" /> <!--定義記錄的日志級別--> <appender-ref ref="ErrorAppender" /> <!--記錄到哪個介質中去--> </logger> <!--信息日志類--> <logger name="loginfo"> <level value="ALL" /> <appender-ref ref="InfoAppender" /> </logger> <!--錯誤日志附加介質--> <appender name="ErrorAppender" type="log4net.Appender.RollingFileAppender"> <!-- name屬性指定其名稱,type則是log4net.Appender命名空間的一個類的名稱,意思是,指定使用哪種介質--> <param name="File" value="D:\Winform\控制臺\log4netDemo2\bin\Log\LogError\\" /> <!--日志輸出到exe程序這個相對目錄下--> <param name="AppendToFile" value="true" /> <!--輸出的日志不會覆蓋以前的信息--> <param name="MaxSizeRollBackups" value="100" /> <!--備份文件的個數--> <param name="MaxFileSize" value="10240" /> <!--當個日志文件的最大大小--> <param name="StaticLogFileName" value="false" /> <!--是否使用靜態文件名--> <param name="DatePattern" value="yyyyMMdd".htm"" /> <!--日志文件名--> <param name="RollingStyle" value="Date" /> <!--文件創建的方式,這里是以Date方式創建--> <!--錯誤日志布局--> <layout type="log4net.Layout.PatternLayout"> <param name="Header" value="<BR>
--------------------------------------------header------------------------------------------------
"/> <param name="ConversionPattern" value="<HR COLOR=red>%n異常時間:%d [%t] <BR>%n異常級別:%-5p <BR>%n異常類:%c [%x] <BR>%n%m <BR>%n <HR Size=1>" /> <param name="Footer" value="<BR>
--------------------------------------------footer------------------------------------------------
"/> </layout> </appender> <!--信息日志附加介質--> <appender name="InfoAppender" type="log4net.Appender.RollingFileAppender"> <param name="File" value="D:\Winform\控制臺\log4netDemo2\bin\Log\LogInfo\\" /> <param name="AppendToFile" value="true" /> <param name="MaxFileSize" value="10240" /> <param name="MaxSizeRollBackups" value="100" /> <param name="StaticLogFileName" value="false" /> <param name="DatePattern" value="yyyyMMdd".htm"" /> <param name="RollingStyle" value="Date" /> <!--信息日志布局--> <layout type="log4net.Layout.PatternLayout"> <!--這3行表示日志輸出的格式,若不喜歡這樣的樣式,可以查看下面的輸出樣式,自行修改--> <!--<param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n"/>--> <param name="Header" value="<BR>
--------------------------------------------header------------------------------------------------
"/> <param name="ConversionPattern" value="<HR COLOR=blue>%n日誌時間:%d [%t] <BR>%n日誌級別:%-5p <BR>%n日誌類:%c [%x] <BR>%n%m <BR>%n <HR Size=1>" /> <param name="Footer" value="<BR>
--------------------------------------------footer------------------------------------------------
"/> </layout> </appender> <!--如下定義的其他輸入方式--> <!--定義輸出到控制臺命令行中--> <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender"> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" /> </layout> </appender> <!--定義輸出到windows事件中--> <appender name="EventLogAppender" type="log4net.Appender.EventLogAppender"> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" /> </layout> </appender> <!--定義輸出到數據庫中,這里舉例輸出到Access數據庫中,數據庫為C盤的log4net.mdb--> <appender name="AdoNetAppender_Access" type="log4net.Appender.AdoNetAppender"> <connectionString value="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:log4net.mdb" /> <commandText value="INSERT INTO LogDetails ([LogDate],[Thread],[Level],[Logger],[Message]) VALUES (@logDate, @thread, @logLevel, @logger,@message)" /> <!--定義各個參數--> <parameter> <parameterName value="@logDate" /> <dbType value="String" /> <size value="240" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%date" /> </layout> </parameter> <parameter> <parameterName value="@thread" /> <dbType value="String" /> <size value="240" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%thread" /> </layout> </parameter> <parameter> <parameterName value="@logLevel" /> <dbType value="String" /> <size value="240" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%level" /> </layout> </parameter> <parameter> <parameterName value="@logger" /> <dbType value="String" /> <size value="240" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%logger" /> </layout> </parameter> <parameter> <parameterName value="@message" /> <dbType value="String" /> <size value="240" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%message" /> </layout> </parameter> </appender> <!--定義日志的輸出媒介,下面定義日志以四種方式輸出。也可以下面的按照一種類型或其他類型輸出。--> <root> <!--文件形式記錄日志--> <appender-ref ref="LogFileAppender" /> <!--控制臺控制顯示日志--> <!--<appender-ref ref="ConsoleAppender" />--> <!--Windows事件日志--> <!--<appender-ref ref="EventLogAppender" />--> <!-- 如果不啟用相應的日志記錄,可以通過這種方式注釋掉 <appender-ref ref="AdoNetAppender_Access" /> --> </root> </log4net> <startup> <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" /> </startup> </configuration>
二、LogHelper工具類代碼
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace log4netDemo2
{
public class LogHelper
{
public static readonly log4net.ILog loginfo = log4net.LogManager.GetLogger("loginfo");//這里的 loginfo 和 log4net.config 里的名字要一樣
public static readonly log4net.ILog logerror = log4net.LogManager.GetLogger("logerror");//這里的 logerror 和 log4net.config 里的名字要一樣
//INFO
public static void WriteLog(string info)
{
if (loginfo.IsInfoEnabled)
{
loginfo.Info(info);
}
}
//ERROR
public static void WriteLog(string info, Exception ex)
{
if (logerror.IsErrorEnabled)
{
logerror.Error(info, ex);
}
}
}
}
三、測試代碼
using log4net;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Reflection;
using System.Text;
using System.Threading.Tasks;
namespace log4netDemo2
{
class Program
{
static void Main(string[] args)
{
try
{
string a = "FF";
LogHelper.WriteLog(a);
int b = Convert.ToInt32(a);
}
catch (Exception ex)
{
LogHelper.WriteLog(ex.Message.ToString(), ex);
}
}
}
}
四、測試輸出
loginfo
logerror
原文鏈接:https://www.cnblogs.com/wml-it/p/14818006.html
相關推薦
- 2022-03-25 Go語言什么時候該使用指針(go指針的作用)
- 2022-10-31 Python入門之字典的使用教程_python
- 2022-03-14 內存常用的頁面調度算法(頁面調度算法采用什么算法)
- 2023-02-27 c++數組排序的5種方法實例代碼_C 語言
- 2022-11-01 python?類對象的析構釋放代碼演示_python
- 2024-04-07 springboot后端接收前端傳數組參數方法
- 2022-11-21 Golang?Mutex互斥鎖源碼分析_Golang
- 2022-03-29 Android中的xml解析介紹_Android
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支