對(duì)于一個(gè)控制臺(tái)應(yīng)用,比如采用控制臺(tái)應(yīng)用作為宿主的ASP.NET Core應(yīng)用,我們可以將記錄的日志直接輸出到控制臺(tái)上。針對(duì)控制臺(tái)的Logger是一個(gè)類型為ConsoleLogger的對(duì)象,ConsoleLogger對(duì)應(yīng)的LoggerProvider類型為ConsoleLoggerProvider,這兩個(gè)類型都定義在 NuGet包“Microsoft.Extensions.Logging.Console”之中。 本文已經(jīng)同步到《ASP.NET Core框架揭秘》之中]
目錄
一、ConsoleLogger
二、ConsoleLogScope
三、ConsoleLoggerProvider
四、擴(kuò)展方法AddConsole
一、ConsoleLogger
如下所示的代碼片段展示了ConsoleLogger類型的定義。它具有四個(gè)屬性,代表Logger名稱的Name屬性最初由ConsoleLoggerProvider提供,實(shí)際上就是LoggerFactory在創(chuàng)建Logger時(shí)指定的日志類型(Category)。ConsoleLogger的Console屬性代表當(dāng)前控制臺(tái),它的類型為IConsole接口。之所以沒有直接采用System.Console向控制臺(tái)輸出格式化的日志消息,是因?yàn)樾枰峁┛缙脚_(tái)的支持,IConsole接口表示的就是這么一個(gè)與具體平臺(tái)無關(guān)的抽象化的控制臺(tái)。
1: public class ConsoleLogger : ILogger
2: {
網(wǎng)友評(píng)論