詳解log4net的使用
程序中只需要引用log4net.dll文件即可
配置的引用
log4net.Config.XmlConfigurator.Configure();
首先添加以上代碼。
CS程序:在Main方法中添加;
BS程序:Application_Start方法中添加;
或是兩者都可以在AssemblyInfo.cs(Properties中)文件里添加以下的語句:
//設(shè)置獨(dú)立配置文件,log4net.config [assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config" , Watch = true )] //或是默認(rèn)的配置文件 [assembly: log4net.Config.XmlConfigurator(Watch = true )] (配置在web.config文件中)
詳細(xì)配置
log4net,可以把日志輸出到控制臺程序,文件,數(shù)據(jù)庫、郵件,下面貼出四個輸出的配置代碼,其余如window日志等輸出不做闡述。
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<!--首先加入configSections配置節(jié)點(diǎn)-->
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/>
</configSections>
<log4net><br>
<root>
<!--(高) OFF > FATAL > ERROR > WARN > INFO > DEBUG > ALL (低) -->
<!--限制日志記錄級別-->
<level value="all" />
<!--將日志輸出到文件-->
<appender-ref ref="FileAppender"/>
<!--將日志輸出到應(yīng)用程序控制臺-->
<appender-ref ref="ConsoleAppender"/>
<!--將日志寫到郵件中-->
<!--<appender-ref ref="LogSmtpAppender"/>-->
<!--將日志記錄到數(shù)據(jù)庫中??梢圆捎肧QL和存儲過程兩種方式-->
<appender-ref ref="AdoNetAppender"/>
<!--可以同時設(shè)置多個輸出對象,沒用到可以注釋-->
<!--將日志寫到local syslog service (僅用于UNIX環(huán)境下)。-->
<!--<appender-ref ref="LocalSyslogAppender"/>-->
</root><br>
<!--發(fā)郵件-->
<appender name="LogSmtpAppender" type="log4net.Appender.SmtpAppender">
<authentication value="Basic" />
<!--接受郵件的郵箱-->
<to value="7778888@qq.com" />
<!--發(fā)送郵件的郵箱-->
<from value="123456@126.com" />
<!--發(fā)送郵件的郵箱-->
<username value="123456@126.com" />
<!--發(fā)送郵件的郵箱密碼-->
<password value="123456" />
<!--標(biāo)題-->
<subject value="XXX應(yīng)用錯誤日志消息" />
<!--smtp.qq.com-->
<smtpHost value="smtp.126.com" />
<bufferSize value="2048" />
<!--超長部分是否丟棄-->
<lossy value="true" />
<!--日志級別 大于 WARN 的才發(fā)郵件-->
<evaluator type="log4net.Core.LevelEvaluator">
<threshold value="ERROR"/>
</evaluator>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value=" %level :: %message %newlineLogger: %logger%newline Date: %date%newline" />
</layout>
</appender><br>
<!-- 控制臺日志 -->
<appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%n%d{yyyy-MM-dd HH:mm:ss} %m%n" />
</layout>
<!--指定范圍內(nèi)的等級才可以被記錄-->
<!--<filter type="log4net.Filter.LevelRangeFilter">
<param name="LevelMin" value="Info" />
<param name="LevelMax" value="Fatal" />
</filter>-->
</appender >
<!--指定日記記錄方式,以滾動文件的方式(文件記錄)-->
<appender name="FileAppender" type="log4net.Appender.RollingFileAppender">
<!--日志路徑-->
<param name= "File" value= "log/"/>
<!--是否是向文件中追加日志-->
<param name= "AppendToFile" value= "true"/>
<!--log保留天數(shù)-->
<param name= "MaxSizeRollBackups" value= "10"/>
<!--每個文件最大1M-->
<param name="maximumFileSize" value="1MB" />
<!--日志文件名是否是固定不變的-->
<param name= "StaticLogFileName" value= "false"/>
<!--日志文件名格式為:2008-08-31.log-->
<param name= "DatePattern" value= "yyyy-MM-dd".log""/>
<!--日志根據(jù)日期滾動-->
<param name= "RollingStyle" value= "Date"/>
<!--布局-->
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%n記錄時間:%d{yyyy-MM-dd HH:mm:ss} 線程名:[%t] 級別:%p 類名:%c 信息:%m%n" />
<param name="Header" value="----------------------------------------------------------- "/>
</layout>
</appender><br>
<!--數(shù)據(jù)庫日記-->
<appender name="AdoNetAppender" type="log4net.Appender.AdoNetAppender">
<!--設(shè)置為1方便查看結(jié)果,處于性能考慮這里的值應(yīng)該略大一點(diǎn),官方默認(rèn)值是100,BufferSize為緩沖區(qū)大小,只有日志記錄超設(shè)定值才會一塊寫入到數(shù)據(jù)庫-->
<bufferSize value="1" />
<!--sqlserver 引用-->
<connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
<!--連接數(shù)據(jù)庫字符串-->
<connectionString value="data source=.;initial catalog=test;integrated security=false;persist security info=True;User ID=sa;Password=sqlserver;" />
<!--插入到表Log-->
<commandText value="INSERT INTO LogTest ([Date],[Level],[Logger],[Message],[Exception],[Description],[ObjType]) VALUES (@log_date,@log_level, @logger, @message, @exception,@Description,@ObjType)" />
<!--所有參數(shù)-->
<parameter>
<parameterName value="@log_date" />
<dbType value="DateTime" />
<layout type="log4net.Layout.RawTimeStampLayout" />
</parameter>
<parameter>
<parameterName value="@log_level" />
<dbType value="String" />
<size value="50" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%level" />
</layout>
</parameter>
<!--類所在位置-->
<parameter>
<parameterName value="@logger" />
<dbType value="String" />
<size value="255" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%logger" />
</layout>
</parameter>
<parameter>
<parameterName value="@message" />
<dbType value="String" />
<size value="4000" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%message" />
</layout>
</parameter>
<parameter>
<parameterName value="@exception" />
<dbType value="String" />
<size value="2000" />
<layout type="log4net.Layout.ExceptionLayout" />
</parameter>
<!--自定義輸入字段-->
<parameter>
<parameterName value = "@Description"/>
<dbType value = "String"/>
<size value = "50"/>
<layout type = "log4_Test.Log4netExpand.ExpandLayout">
<conversionPattern value = "%property{Description}"/>
</layout>
</parameter>
<parameter>
<parameterName value = "@ObjType"/>
<dbType value = "String"/>
<size value = "50"/>
<layout type = "log4_Test.Log4netExpand.ExpandLayout">
<conversionPattern value = "%property{ObjType}"/>
</layout>
</parameter>
</appender>
</log4net>
</configuration>
<layout type = "log4_Test.Log4netExpand.ExpandLayout"> 中的log4_Test.Log4netExpand 為命名空間
布局、格式字符說明:
%p:輸出日志信息的優(yōu)先級,即DEBUG,INFO,WARN,ERROR,F(xiàn)ATAL。
%d:輸出日志時間點(diǎn)的日期或時間,默認(rèn)格式為ISO8601,也可以在其后指定格式,如:%d{yyyy/MM/dd HH:mm:ss,SSS}。
%r:輸出自應(yīng)用程序啟動到輸出該log信息耗費(fèi)的毫秒數(shù)。
%t:輸出產(chǎn)生該日志事件的線程名。
%l:輸出日志事件的發(fā)生位置,相當(dāng)于%c.%M(%F:%L)的組合,包括類全名、方法、文件名以及在代碼中的行數(shù)。例如:test.TestLog4j.main(TestLog4j.java:10)。
%c:輸出日志信息所屬的類目,通常就是所在類的全名。
%M:輸出產(chǎn)生日志信息的方法名。
%F:輸出日志消息產(chǎn)生時所在的文件名稱。
%L::輸出代碼中的行號。
%m::輸出代碼中指定的具體日志信息。
%n:輸出一個回車換行符,Windows平臺為"\r\n",Unix平臺為"\n"。
%x:輸出和當(dāng)前線程相關(guān)聯(lián)的NDC(嵌套診斷環(huán)境),尤其用到像java servlets這樣的多客戶多線程的應(yīng)用中。
%%:輸出一個"%"字符。
另外,還可以在%與格式字符之間加上修飾符來控制其最小長度、最大長度、和文本的對齊方式。如:
1)%20c:指定輸出category的名稱,最小的長度是20,如果category的名稱長度小于20的話,默認(rèn)的情況下右對齊。
2)%-20c:"-"號表示左對齊。
3)%.30c:指定輸出category的名稱,最大的長度是30,如果category的名稱長度大于30的話,就會將左邊多出的字符截掉,但小于30的話也不會補(bǔ)空格。
自定義數(shù)據(jù)庫插入字段(源自網(wǎng)絡(luò)收集、整理)
1.先定義一個LogData類:
namespace log4_Test.Log4netExpand
{
public class LogData
{
/// <summary>
/// 日志描述信息
/// </summary>
public string Description { get; set; }
/// <summary>
/// 日志描述信息
/// </summary>
public string ObjType { get; set; }
}
}
2.Layout擴(kuò)展類
namespace log4_Test.Log4netExpand
{
public class ExpandLayout : PatternLayout
{
public ExpandLayout()
{
this.AddConverter("property", typeof(MyMessagePatternConverter));
}
}
}
3.MyMessagePatternConverter 類
namespace log4_Test.Log4netExpand
{
public class MyMessagePatternConverter: PatternLayoutConverter
{
protected override void Convert(System.IO.TextWriter writer, log4net.Core.LoggingEvent loggingEvent)
{
if (Option != null)
{
// Write the value for the specified key
WriteObject(writer, loggingEvent.Repository, LookupProperty(Option, loggingEvent));
}
else
{
// Write all the key value pairs
WriteDictionary(writer, loggingEvent.Repository, loggingEvent.GetProperties());
}
}
/// <summary>
/// 通過反射獲取傳入的日志對象的某個屬性的值
/// </summary>
/// <param name="property"></param>
/// <returns></returns>
private object LookupProperty(string property, log4net.Core.LoggingEvent loggingEvent)
{
object propertyValue = string.Empty;
PropertyInfo propertyInfo = loggingEvent.MessageObject.GetType().GetProperty(property);
if (propertyInfo != null)
{
propertyValue = propertyInfo.GetValue(loggingEvent.MessageObject, null);
}
return propertyValue;
}
}
}
4.使用代碼如下:
public class Program
{
static void Main(string[] args)
{
//能看到是那個類輸出
ILog logger = log4net.LogManager.GetLogger(typeof(Program));
logger.Info(new LogData { Description="123", ObjType="123"})
logger.Info("消息11111111111111111111111111111");
logger.Warn("警告");
logger.Error("異常");
logger.Fatal("錯誤");
}
}
以上所述是小編給大家介紹的log4net的使用詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
ASP.NET中repeater嵌套實(shí)現(xiàn)代碼(附源碼)
repeater嵌套經(jīng)常會在一些特殊效果顯示下會用到,新手朋友們可以詳細(xì)看下本文,希望對你有所幫助,代碼很整潔同時附有源碼2013-03-03
MVC+EasyUI+三層新聞網(wǎng)站建立 驗(yàn)證碼生成(三)
這篇文章主要為大家詳細(xì)介紹了MVC+EasyUI+三層新聞網(wǎng)站建立的第三篇,教大家如何生成驗(yàn)證碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07
IdentityServer4實(shí)現(xiàn).Net Core API接口權(quán)限認(rèn)證(快速入門)
這篇文章主要介紹了IdentityServer4實(shí)現(xiàn).Net Core API接口權(quán)限認(rèn)證,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03
c#將Excel數(shù)據(jù)導(dǎo)入到數(shù)據(jù)庫的實(shí)現(xiàn)代碼
這篇文章主要介紹了c#將Excel數(shù)據(jù)導(dǎo)入到數(shù)據(jù)庫的實(shí)現(xiàn)代碼,有需要的朋友可以參考一下2013-12-12
.NET Core創(chuàng)建一個控制臺(Console)程序
這篇文章主要為大家詳細(xì)介紹了.NET Core如何創(chuàng)建一個控制臺程序,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04

