Entity Framework Core ha un motore di logging potente, ma leggermente più complesso da utilizzare rispetto a Entity Framework 6. Entity Framework Core richiede la creazione di una factory che è responsabile della creazione della vera classe di logging. La factory deve poi essere iniettata nel contesto che la utilizza per loggare informazioni.
Il primo passo per creare un logger custom consiste nel creare la classe di logging che come unico requisito ha quello di implementare l'interfaccia ILogger.
class MyLogger : ILogger { public bool IsEnabled(LogLevel logLevel) => true; public void Log<TState>(LogLevel logLevel, EventId eventId, TState state, Exception exception, Func<TState, Exception, string> formatter) { File.AppendAllText(@"C:\temp\log.txt", formatter(state, exception)); } public IDisposable BeginScope<TState>(TState state) => null; }
La parte di logging viene effettuata nel metodo Log. In questo caso scriviamo su file, ma possiamo scrivere su un altro database, invocare un servizio, scrivere in cache e molto altro ancora.
A questo punto dobbiamo creare la factory che crea la classe MyLogger e che viene poi iniettata nel contesto. La classe deve implementare l'interfaccia ILoggerProvider.
public class MyLoggerProvider : ILoggerProvider { public ILogger CreateLogger(string categoryName) { return new MyLogger(); } public void Dispose() {}
Ora non rimane che iniettare la la factory in fase di inizializzazione del contesto.
using (var ctx = new MyContext()) { var serviceProvider = ctx.GetInfrastructure<IServiceProvider>(); var loggerFactory = serviceProvider.GetService<ILoggerFactory>(); loggerFactory.AddProvider(new MyLoggerProvider()); }
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Routing statico e PreRendering in una Blazor Web App
Utilizzare Model as a Service su Microsoft Azure
Applicare il versioning ai nostri endpoint ASP.NET Core Minimal API
Disabilitare automaticamente un workflow di GitHub (parte 2)
Evitare la command injection in un workflow di GitHub
Sfruttare lo streaming di una chiamata Http da Blazor
Specificare il versioning nel path degli URL in ASP.NET Web API
Implementare il throttling in ASP.NET Core
Cambiare la chiave di partizionamento di Azure Cosmos DB
Eseguire attività pianificate con Azure Container Jobs
Usare le collection expression per inizializzare una lista di oggetti in C#
Autenticarsi in modo sicuro su Azure tramite GitHub Actions
I più letti di oggi
- Ottimizzare le performance delle collection con le classi FrozenSet e FrozenDictionary
- ASP.NET 3.5 per tutti
- .NET Conference Italia 2023 - Milano e Online
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Utilizzare Docker Compose con Azure App Service
- Creare più ambienti in un'applicazione Angular