log4net在Asp.net MVC4中的使用過(guò)程
1、安裝log4net插件
新建Asp.net MVC4項(xiàng)目,并在Nuget控制臺(tái)輸入命令,或者直接搜索log4net在線安裝,安裝log4net
>Install-Package log4net -Version 2.0.15
2、配置web.config文件
<?xml version="1.0" encoding="utf-8"?> <!-- 有關(guān)如何配置 ASP.NET 應(yīng)用程序的詳細(xì)信息,請(qǐng)?jiān)L問(wèn) https://go.microsoft.com/fwlink/?LinkId=301880 --> <configuration> <configSections> <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/> </configSections> <log4net> <root> <level value="ALL"></level> <appender-ref ref="SysAppender"></appender-ref> </root> <logger name="WebLogger"> <!--日志輸出級(jí)別限制,只有大于或等于DEBUG級(jí)別才記錄日志--> <level value="DEBUG"></level> </logger> <!--以滾動(dòng)日志方式記錄日志--> <appender name="SysAppender" type="log4net.Appender.RollingFileAppender,log4net"> <!--文件存放路徑,在項(xiàng)目根目錄App_Data下--> <param name="File" value="App_Data/"></param> <!--日志是否追加到文件--> <param name="AppendToFile" value="true"></param> <!--滾動(dòng)日志文件按照日期風(fēng)格生成--> <param name="RollingStyle" value="Date"></param> <!--日志文件的命名規(guī)則--> <param name="DatePattern" value=""Logs_"yyyyMMdd".txt""></param> <!--日志名稱(chēng)是否靜態(tài)--> <param name="StaticLogFileName" value="false"></param> <!--日志內(nèi)容的格式和布局--> <layout type="log4net.Layout.PatternLayout,log4net"> <param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n"></param> <param name="Header" value="-------------------------header---------------------------"></param> <param name="Footer" value="-------------------------footer---------------------------"></param> </layout> </appender> <!--按照控制臺(tái)輸出日志--> <appender name="ConsoleApp" type="log4net.Appender.ConsoleAppender,log4net"> <layout type="log4net.Layout.PatternLayout,log4net"> <param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n"></param> </layout> </appender> </log4net> <appSettings> <add key="webpages:Version" value="3.0.0.0" /> <add key="webpages:Enabled" value="false" /> <add key="ClientValidationEnabled" value="true" /> <add key="UnobtrusiveJavaScriptEnabled" value="true" /> </appSettings> <system.web> <compilation debug="true" targetFramework="4.6.1" /> <httpRuntime targetFramework="4.6.1" /> <httpModules> <add name="ApplicationInsightsWebTracking" type="Microsoft.ApplicationInsights.Web.ApplicationInsightsHttpModule, Microsoft.AI.Web" /> </httpModules> </system.web> <runtime> <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1"> <dependentAssembly> <assemblyIdentity name="Antlr3.Runtime" publicKeyToken="eb42632606e9261f" /> <bindingRedirect oldVersion="0.0.0.0-3.5.0.2" newVersion="3.5.0.2" /> </dependentAssembly> <dependentAssembly> <assemblyIdentity name="System.Diagnostics.DiagnosticSource" publicKeyToken="cc7b13ffcd2ddd51" /> <bindingRedirect oldVersion="0.0.0.0-4.0.2.1" newVersion="4.0.2.1" /> </dependentAssembly> <dependentAssembly> <assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" /> <bindingRedirect oldVersion="0.0.0.0-11.0.0.0" newVersion="11.0.0.0" /> </dependentAssembly> <dependentAssembly> <assemblyIdentity name="System.Web.Optimization" publicKeyToken="31bf3856ad364e35" /> <bindingRedirect oldVersion="1.0.0.0-1.1.0.0" newVersion="1.1.0.0" /> </dependentAssembly> <dependentAssembly> <assemblyIdentity name="WebGrease" publicKeyToken="31bf3856ad364e35" /> <bindingRedirect oldVersion="0.0.0.0-1.6.5135.21930" newVersion="1.6.5135.21930" /> </dependentAssembly> <dependentAssembly> <assemblyIdentity name="System.Web.Helpers" publicKeyToken="31bf3856ad364e35" /> <bindingRedirect oldVersion="1.0.0.0-3.0.0.0" newVersion="3.0.0.0" /> </dependentAssembly> <dependentAssembly> <assemblyIdentity name="System.Web.WebPages" publicKeyToken="31bf3856ad364e35" /> <bindingRedirect oldVersion="1.0.0.0-3.0.0.0" newVersion="3.0.0.0" /> </dependentAssembly> <dependentAssembly> <assemblyIdentity name="System.Web.Mvc" publicKeyToken="31bf3856ad364e35" /> <bindingRedirect oldVersion="1.0.0.0-5.2.4.0" newVersion="5.2.4.0" /> </dependentAssembly> </assemblyBinding> </runtime> <system.webServer> <modules> <remove name="TelemetryCorrelationHttpModule" /> <add name="TelemetryCorrelationHttpModule" type="Microsoft.AspNet.TelemetryCorrelation.TelemetryCorrelationHttpModule, Microsoft.AspNet.TelemetryCorrelation" preCondition="integratedMode,managedHandler" /> <remove name="ApplicationInsightsWebTracking" /> <add name="ApplicationInsightsWebTracking" type="Microsoft.ApplicationInsights.Web.ApplicationInsightsHttpModule, Microsoft.AI.Web" preCondition="managedHandler" /> </modules> <validation validateIntegratedModeConfiguration="false" /> </system.webServer> <system.codedom> <compilers> <compiler language="c#;cs;csharp" extension=".cs" type="Microsoft.CodeDom.Providers.DotNetCompilerPlatform.CSharpCodeProvider, Microsoft.CodeDom.Providers.DotNetCompilerPlatform, Version=2.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" warningLevel="4" compilerOptions="/langversion:default /nowarn:1659;1699;1701" /> <compiler language="vb;vbs;visualbasic;vbscript" extension=".vb" type="Microsoft.CodeDom.Providers.DotNetCompilerPlatform.VBCodeProvider, Microsoft.CodeDom.Providers.DotNetCompilerPlatform, Version=2.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" warningLevel="4" compilerOptions="/langversion:default /nowarn:41008 /define:_MYTYPE=\"Web\" /optionInfer+" /> </compilers> </system.codedom> </configuration>
日志級(jí)別分類(lèi)(從高到低):OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL
3、初始化log4net
在Global.asax中初始化log4net配置
log4net.Config.XmlConfigurator.Configure();
4、定義異常攔截器
自定義異常攔截器,出現(xiàn)控制器action方法調(diào)用出現(xiàn)異常時(shí),將異常信息統(tǒng)一加入到全局隊(duì)列中,避免日志寫(xiě)入文件并發(fā)沖突。
public class MyErrorAttribute:HandleErrorAttribute { public static Queue<Exception> ExceptionQueue = new Queue<Exception>(); public override void OnException(ExceptionContext filterContext) { ExceptionQueue.Enqueue(filterContext.Exception); base.OnException(filterContext); } }
將全局默認(rèn)異常處理器替換為自己定義的。
public class FilterConfig { public static void RegisterGlobalFilters(GlobalFilterCollection filters) { //filters.Add(new HandleErrorAttribute());//默認(rèn)異常處理器 filters.Add(new MyErrorAttribute());//自定義異常處理器 } }
5、后臺(tái)線程輪詢(xún)異常隊(duì)列,將日志寫(xiě)入到文件
啟動(dòng)類(lèi)Global.asax.cs文件中定義后臺(tái)線程,處理異常隊(duì)列中日志的輸出
//啟動(dòng)后臺(tái)線程,周期性輪詢(xún)異常隊(duì)列,將異常輸出到文件 ThreadPool.QueueUserWorkItem(o => { while(true) { if(MyErrorAttribute.ExceptionQueue.Count>0) { Exception ex = MyErrorAttribute.ExceptionQueue.Dequeue(); if(ex!=null) { ILog log = LogManager.GetLogger("testError"); log.Error(ex.ToString()); } else { Thread.Sleep(50); } } else { Thread.Sleep(50); } } });
6、控制器中定義異常測(cè)試方法
public ActionResult TestLog() { int result = 0; int x = 1, y = 0; result = x / y; return View(); }
7、啟動(dòng)程序測(cè)試action方法
查看項(xiàng)目根目錄App_Data,生成了日志文件Logs_20230520.txt
查看日志內(nèi)容
到此這篇關(guān)于log4net在Asp.net MVC4中的使用的文章就介紹到這了,更多相關(guān)Asp.net MVC4使用log4net內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在 .NET Core 中使用 Diagnostics (Diagnostic Source) 記錄跟蹤信息
今天給大家講一下在 .NET Core 2 中引入的全新 DiagnosticSource 事件機(jī)制,為什么說(shuō)是全新呢? 在以前的 .NET Framework 有心的同學(xué)應(yīng)該知道也有 Diagnostics,那么新的 .NET Core 中有什么變化呢?跟隨小編一起看看吧2021-06-06利用委托把用戶(hù)控件的值顯示于網(wǎng)頁(yè)案例應(yīng)用
用戶(hù)控件(UserControl)是集成一個(gè)功能,需要處理好的數(shù)據(jù),然后存數(shù)據(jù)庫(kù)中并顯示于網(wǎng)頁(yè)上,讓用戶(hù)能檢測(cè)到處理的數(shù)據(jù)情況,接下來(lái)將介紹利用委托把用戶(hù)控件的值顯示于網(wǎng)頁(yè)上,感興趣的朋友可以了解下2013-02-02在.NetCore(C#)中使用ODP.NET Core+Dapper操作Oracle數(shù)據(jù)庫(kù)
這篇文章主要介紹了在.NetCore(C#)中使用ODP.NET Core+Dapper操作Oracle數(shù)據(jù)庫(kù),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02ASP.NET Core MVC基礎(chǔ)學(xué)習(xí)之局部視圖(Partial Views)
這篇文章主要給大家介紹了關(guān)于ASP.NET Core MVC基礎(chǔ)學(xué)習(xí)之局部視圖(Partial Views)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用ASP.NET Core MVC具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08ASP.NET?Core使用EF創(chuàng)建模型(索引、備用鍵、繼承、支持字段)
這篇文章介紹了ASP.NET?Core使用EF創(chuàng)建模型的的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-04-04.NET Core應(yīng)用類(lèi)型(Portable apps & Self-contained apps)
這篇文章主要介紹了.NET Core應(yīng)用類(lèi)型,通常類(lèi)型用來(lái)描述一個(gè)特定的執(zhí)行模型或者基于此的應(yīng)用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-04-04Path類(lèi)與Directory類(lèi)與File類(lèi)對(duì)路徑/目錄/文件的操作實(shí)例
本文將詳細(xì)介紹下:Path對(duì)路徑字符串進(jìn)行操作/Directory和DirectoryInfo 對(duì)目錄進(jìn)行操作/File和FileInfo對(duì)文件進(jìn)行操作,感興趣的你可不要錯(cuò)過(guò)了哈2013-02-02基于.NET程序默認(rèn)啟動(dòng)線程數(shù)講解
本篇文章小編為大家介紹,基于.NET程序默認(rèn)啟動(dòng)線程數(shù)講解。需要的朋友參考下2013-04-04