您好,登錄后才能下訂單哦!
本篇內(nèi)容介紹了“.Net Core中如何自定義日志組件”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
在日志工廠記錄器(ILoggerFactory
)中實(shí)現(xiàn)將日志記錄提供器(ILoggerProvider
)對(duì)象都可以集成到Logger
對(duì)象組合中,這樣的話,我們就可以通過(guò)基于ILoggerProvider
自定義日志記錄程序集成到Logger
中,再創(chuàng)建寫(xiě)日志定義Ilogger
,自定義日志記錄器實(shí)現(xiàn)日志的輸出方式,這樣實(shí)現(xiàn)自定義日志記錄工具。
在這個(gè)過(guò)程中,日志記錄器ILogger
中的Log()方法會(huì)記錄執(zhí)行日志,通過(guò)在ILoggerFactory
產(chǎn)生的是ILogger
類(lèi)型(也就是我們最終使用的Logger
),其Log()方法是依次調(diào)用Logger
中包含的LoggerInformation[]
數(shù)組中的ILogger
。而ILoggerProvider
產(chǎn)生的為各類(lèi)不同的XxxLogger(也就是上面說(shuō)的Logger
中的LoggerInformation
數(shù)組包含的如ConsoleLogger、DebugLogger
),其Log()方法是把日志寫(xiě)到具體的目標(biāo)上去,所以我們自定義的日志程序也可以在日志記錄器工廠中實(shí)現(xiàn)添加日志程序,達(dá)到將日志寫(xiě)到具體目標(biāo)的作用。
創(chuàng)建一個(gè)自定義Logger,目的是將指定的等級(jí)日志輸出到控制臺(tái)。所以我們創(chuàng)建一個(gè)ExtensionLogger
的類(lèi),指定輸出的日志等級(jí)。所以在這之前,我們需要配置一下輸入日志的等級(jí),因此我們需要增加一個(gè)等級(jí)的配置類(lèi)ExtensionsConfiguration
。
在ExtensionsConfiguration
中,
public class ExtensionsConfiguration { /// <summary> /// 日志等級(jí) /// </summary> public LogLevel LogLevel { get; set; } = LogLevel.Warning; }
再自定義日志記錄類(lèi)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)的日志。
在創(chuàng)建了日志輸出記錄后,我們同時(shí)需要提供一個(gè)日志程序來(lái)增加和創(chuàng)建上面的Logger
記錄,所以我們通過(guò)自定義日志提供器類(lèi)ExtensionsLoggerProvider
,實(shí)現(xiàn)ILoggerProvider
類(lèi)。
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)自定義類(lèi),實(shí)現(xiàn)方法CreateLogger
,來(lái)創(chuàng)建上面的日志記錄。
在Startup.cs中,通過(guò)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)的日志記錄。
在等級(jí)為Information
情況下,輸出效果如下:
這個(gè)就是我們通過(guò)自定義的方式實(shí)現(xiàn)的按日志等級(jí)輸出的記錄。
第一步:為L(zhǎng)oggerFactory擴(kuò)張一個(gè)方法,提供增加日志寫(xiě)文件方式的入口。相關(guān)的配置來(lái)自appsettings.json
第二步:實(shí)現(xiàn)我們的logger提供程序,實(shí)現(xiàn)ILoggerProvider接口,關(guān)鍵方法CreateLogger,創(chuàng)建真正寫(xiě)日志的logger。對(duì)當(dāng)前的logger可以做適當(dāng)?shù)木彺?,配置logger
第三步:實(shí)現(xiàn)我們的logger,實(shí)現(xiàn)ILogger接口。真正將log寫(xiě)入file。
“.Net Core中如何自定義日志組件”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。