LoggerFactory class'ı ne işe yarar ?
LoggerFactory class'ı asp.net core projemizde yeni bir ILogger instance'ı üretmemize olanak sağlar.
Örnek :
1.) Logger adlı bir klasör oluşturun ve içerisine Logger ve LoggerFileProvide adlı iki tane class oluşturun :
2.) Logger class'ımızı ILogger adlı interface'den türetin ve içine şu kodları yapıştırın :
public string Path { get; set; } public Logger(string FullPath) { Path = FullPath; } public IDisposable BeginScope<TState>(TState state) { return null; } public bool IsEnabled(LogLevel logLevel) { return true; } public void Log<TState>(LogLevel logLevel, EventId eventId, TState state, Exception exception, Func<TState, Exception, string> formatter) { File.AppendAllText($"{Path}",$"LogLevel: { logLevel } | EventId: { eventId }| TState : { state } | Exception : { exception } | Formatter : { formatter } + Datetime : {DateTime.Now} "+ Environment.NewLine + Environment.NewLine); }
3.) LoggerFileProvide class'ımızı "ILoggerProvider" adlı interfaceden türetin ve içine aşağıdaki kodları yapıştırın :
public string Path { get; set; } public LoggerFileProvider(string FullPath) { Path = FullPath; } public ILogger CreateLogger(string categoryName) { return new Logger(Path); } public void Dispose() { throw new NotImplementedException(); }
4.) HomeController.cs ye gidelim ve ILogger tipinden yeni bir field oluşturalım örneğin aşağıdaki gibi :
private readonly ILogger _logger2;
5.) HomeController.cs controllerının constructor'ına aşağıdaki kodları yapıştıralım :
_logger2 = LoggerFactory.Create(configure => { configure.AddProvider(new LoggerFileProvider("C:\\Loglama\\Logging.txt")); }).CreateLogger("Bu farklı bir logger.");
6.) HomeController.cs dosyasının içerisindeki Index action'ın içine aşağıdaki kodları yapıştıralım :
_logger.LogInformation("Bu bir mesajdır ve console yazılacaktır."); _logger2.LogInformation("Bu bir mesajdır ve C:\\Loglama\\Logging.txt yoluna yazılacaktır.");
7.) Son hali olarak dosyalarımız aşağıdakine benzer gözükmelidir, teyit amaçlı fotoğlarını koyuyorum :
Logger.cs :
LoggerFileProvide.cs :
HomeController.cs :
8.) "C:\" dizinine "Loglama" adlı klasör yaratalım. "Loglama" adlı klasör'ün içerisine "Logging.txt" adlı txt dosyasını yaratalım.
Dikkat ederseniz bu parametreyi "C:\Loglama\Logging.txt" HomeController'ın constructor'ında verdik tekrar amaçlı buraya kodu bırakıyorum :
_logger2 = LoggerFactory.Create(configure => { configure.AddProvider(new LoggerFileProvider("C:\\Loglama\\Logging.txt")); // burada hangi dosyaya loglama yapacağını bildiriyoruz. }).CreateLogger("Bu farklı bir logger.");
9.) Projen dosyasının üstüne sağ tıklayıp "Open in Terminal" diyelim :
10.) Çıkan terminale "dotnet run" yazalım.
11.) Ve tarayıcımızı açıp aşağıdaki linke gidelim :
https://localhost:5001
Burası bizi Home/Index yönlendirecektir.
12.) Sayfamız yüklendikten sonra terminale bakalım :
info: LogFabrikası.Controllers.HomeController[0] Bu bir mesajdır ve console yazılacaktır.
yazacaktır.
13.) Şimdi ise : "C:\Loglama\Logging.txt" yolundaki dosyaya açalım. Aşağıdaki gibi bir mesajı olan Loglama işlemi gerçeleşmiş olması gerekir.
LogLevel: Information | EventId: 0| TState : Bu bir mesajdır ve C:\Loglama\Logging.txt yoluna yazılacaktır. | Exception : | Formatter : System.Func`3[Microsoft.Extensions.Logging.FormattedLogValues,System.Exception,System.String] + Datetime : 10.10.2021 19:30:42
Sizde zaman vs.. farklı olabilir ama önemli olan 6. adımda yapmış olduğumuz _logger2.LogInformatin(...) metodumuzun içerisindeki yazıyı yazdırmasıdır.
Sonuç :
LoggerFactory class'ı ile yeni Logger'lar oluşturabilirsiniz.
Bir dahaki yazımda görüşmek dileğiyle.
En iyi dileklerim ile.
Mustafa Samed Yeyin.
Top comments (0)