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)