.Net Core日志記錄之自定義日志組件
一、前言
在上一篇中,我們通過學(xué)習(xí)了解在.net core 中內(nèi)置的日志記錄中的幾大核心要素,在日志工廠記錄器(ILoggerFactory)中實(shí)現(xiàn)將日志記錄提供器(ILoggerProvider)對(duì)象都可以集成到Logger對(duì)象組合中,這樣的話,我們就可以通過基于ILoggerProvider自定義日志記錄程序集成到Logger中,再創(chuàng)建寫日志定義Ilogger,自定義日志記錄器實(shí)現(xiàn)日志的輸出方式,這樣實(shí)現(xiàn)自定義日志記錄工具。
在這個(gè)過程中,日志記錄器ILogger中的Log()方法會(huì)記錄執(zhí)行日志,通過在ILoggerFactory產(chǎn)生的是ILogger類型(也就是我們最終使用的Logger),其Log()方法是依次調(diào)用Logger中包含的LoggerInformation[]數(shù)組中的ILogger。而ILoggerProvider產(chǎn)生的為各類不同的XxxLogger(也就是上面說的Logger中的LoggerInformation數(shù)組包含的如ConsoleLogger、DebugLogger),其Log()方法是把日志寫到具體的目標(biāo)上去,所以我們自定義的日志程序也可以在日志記錄器工廠中實(shí)現(xiàn)添加日志程序,達(dá)到將日志寫到具體目標(biāo)的作用。
所以下文我們通過自定義的方式實(shí)現(xiàn)ILogger、ILoggerProvider兩個(gè)接口來實(shí)現(xiàn)我們自己想要的日志記錄程序,實(shí)現(xiàn)自定義輸出目標(biāo)方式。(下文只是簡單的根據(jù)接口自定義實(shí)現(xiàn)輸出日志記錄到控制臺(tái)的demo)
二、開始
2.1 自定義Logger
創(chuàng)建一個(gè)自定義Logger,目的是將指定的等級(jí)日志輸出到控制臺(tái)。所以我們創(chuàng)建一個(gè)ExtensionLogger的類,指定輸出的日志等級(jí)。所以在這之前,我們需要配置一下輸入日志的等級(jí),因此我們需要增加一個(gè)等級(jí)的配置類ExtensionsConfiguration。
在ExtensionsConfiguration中,
public class ExtensionsConfiguration
{
/// <summary>
/// 日志等級(jí)
/// </summary>
public LogLevel LogLevel { get; set; } = LogLevel.Warning;
}再自定義日志記錄類ExtensionLogger,實(shí)現(xiàn)接口ILogger,
public class ExtensionsLogger : ILogger
{
private readonly ExtensionsConfiguration _config;
public ExtensionsLogger(ExtensionsConfiguration extensionsConfiguration)
{
_config = extensionsConfiguration;
}
public IDisposable BeginScope<TState>(TState state)
{
return null;
}
public bool IsEnabled(LogLevel logLevel)
{
return logLevel == _config.LogLevel;
}
public void Log<TState>(LogLevel logLevel, EventId eventId, TState state,
Exception exception, Func<TState, Exception, string> formatter)
{
if (!IsEnabled(logLevel))
{
return;
}
Console.WriteLine($" {logLevel} - {eventId.Id} : " + formatter(state, exception));
}
}
根據(jù)ILogger接口實(shí)現(xiàn),其中實(shí)現(xiàn)Log()接口方法,將日志輸出到指定目標(biāo),這里是輸出到控制臺(tái),在設(shè)置了日志等級(jí)的情況條件下,當(dāng)滿足條件后,才能輸出對(duì)應(yīng)的日志。
2.2 自定義LoggerProvider
在創(chuàng)建了日志輸出記錄后,我們同時(shí)需要提供一個(gè)日志程序來增加和創(chuàng)建上面的Logger記錄,所以我們通過自定義日志提供器類ExtensionsLoggerProvider,實(shí)現(xiàn)ILoggerProvider類。
public class ExtensionsLoggerProvider : ILoggerProvider
{
private readonly ExtensionsConfiguration _config;
public ExtensionsLoggerProvider(ExtensionsConfiguration extensionsConfiguration)
{
_config = extensionsConfiguration;
}
public ILogger CreateLogger(string categoryName)
{
return new ExtensionsLogger(_config);
}
public void Dispose()
{
}
}基于ILoggerProvider接口實(shí)現(xiàn)自定義類,實(shí)現(xiàn)方法CreateLogger,來創(chuàng)建上面的日志記錄。
2.3 使用
在Startup.cs中,通過Configure方法調(diào)用配置日志記錄。
public void Configure(IApplicationBuilder app, IWebHostEnvironment env , ILoggerFactory loggerFactory)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
// 注入ILogggerFactory,然后配置參數(shù)
//添加日志等級(jí)
loggerFactory.AddProvider(new ExtensionsLoggerProvider(new ExtensionsConfiguration { LogLevel= LogLevel.Warning }));
app.UseRouting();
app.UseAuthorization();
app.UseEndpoints(endpoints =>
{
endpoints.MapControllers();
});
}在此之前,我們可以清空默認(rèn)的配置,然后根據(jù)日志等級(jí),在控制臺(tái)中輸出對(duì)應(yīng)的日志記錄。
2.4 效果
在等級(jí)為Information情況下,輸出效果如下:

這個(gè)就是我們通過自定義的方式實(shí)現(xiàn)的按日志等級(jí)輸出的記錄。
三、拓展
3.1 寫入本地文件
第一步:為LoggerFactory擴(kuò)張一個(gè)方法,提供增加日志寫文件方式的入口。相關(guān)的配置來自appsettings.json
第二步:實(shí)現(xiàn)我們的logger提供程序,實(shí)現(xiàn)ILoggerProvider接口,關(guān)鍵方法CreateLogger,創(chuàng)建真正寫日志的logger。對(duì)當(dāng)前的logger可以做適當(dāng)?shù)木彺妫渲胠ogger
第三步:實(shí)現(xiàn)我們的logger,實(shí)現(xiàn)ILogger接口。真正將log寫入file。
這里可以參考網(wǎng)友的資料 :.Net Core Logger 實(shí)現(xiàn)log寫入本地文件系統(tǒng)
四、總結(jié)
上文中,我們通過自定義的方式實(shí)現(xiàn)了根據(jù)日志等級(jí)將日志記錄輸出到指定目標(biāo)的方式,在這種基礎(chǔ)上,我們可以根據(jù)具體的需求做完善修改,實(shí)現(xiàn)自己的日志記錄輸出方式。
除了我們通過自定義的方式之外,我們也可以借用第三方日志框架組件程序進(jìn)行使用,根據(jù)拓展方法進(jìn)行調(diào)用,在后續(xù)中我們會(huì)使用第三方日志記錄程序來實(shí)現(xiàn)日志記錄的輸出。
如果有不對(duì)的或不理解的地方,希望大家可以多多指正,提出問題,一起討論,不斷學(xué)習(xí),共同進(jìn)步。
到此這篇關(guān)于.Net Core自定義日志組件的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Repeater控件動(dòng)態(tài)變更列(Header,Item和Foot)信息實(shí)現(xiàn)思路
需求開發(fā)一個(gè)小報(bào)表,顯示最近五個(gè)月的summary的數(shù)量統(tǒng)計(jì),報(bào)表會(huì)隨月份的變化而變化,接下來為大家詳細(xì)介紹下實(shí)現(xiàn)方法,感興趣的各位不要錯(cuò)過了哈2013-03-03
C#下載文件(TransmitFile/WriteFile/流方式)實(shí)例介紹
C#下載文件想必很多業(yè)內(nèi)人士都不會(huì)陌生吧,C#下載文件方法很多,本文整理了一些,可供大家參考,感興趣的你可以研究下,或許本文所提供的知識(shí)點(diǎn)對(duì)你有所幫助2013-02-02
ASP.NET Core環(huán)境變量配置和啟動(dòng)設(shè)置講解
這篇文章介紹了ASP.NET Core環(huán)境變量配置和啟動(dòng)設(shè)置的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-02-02
MVC+EasyUI+三層架構(gòu)簡單權(quán)限管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了MVC+EasyUI+三層架構(gòu)簡單權(quán)限管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-07-07
Asp.net保持頁面滾動(dòng)條位置(頁面提交后不變)
ASP.net:保持頁面中滾動(dòng)條的位置,使得頁面提交后還在原來的位置,對(duì)于頁面中DIV等等的滾動(dòng)條控制,我在看了別人代碼后,寫了一個(gè),感興趣的朋友可以參考下哈2013-04-04
ASP.NET中application對(duì)象的使用介紹
這篇文章主要介紹了ASP.NET中application對(duì)象的使用,需要的朋友可以參考下2014-03-03

