Registro de erros simples e conveniente para sites .NET Core

Talvez muitos estejam familiarizados com a biblioteca ELMAH (Módulos e Manipuladores de Log de Erros) , que permite organizar o log de erros simples para qualquer site criado com o .NET Framework.













Esta ferramenta simples e comprovada tem me ajudado em muitos projetos.

Vários anos atrás, enquanto criava meu novo projeto para .NET Core, fiquei chateado ao descobrir que ELMAH não funciona no .NET Core.







opensource ! , ELMAH .NET Core.







, , pet-. , , «» ElmahCore.







, ElmahCore – opensource , , .NET Core.

, , :







  • ,
  • HTTP : (header), , cookies,


, Microsoft.Extensions.Logging (ILogger) HTTP .

:







  • XML
  • , MSSQL, MySQL, PostgreSQL


:







  1. nuget- elmahcore.
  2. Startup.cs:


services.AddElmah(); //   ConfigureServices 
app.UseElmah(); //    Configure
      
      





.

, , ~/elmah.

UI, VUE.js













, . :







services.AddElmah(options =>
{
   options.SourcePaths = new []
   {
      @"D:\tmp\ElmahCore.DemoCore3",
      @"D:\tmp\ElmahCore.Mvc",
      @"D:\tmp\ElmahCore"
   };
});

      
      





«Log» Microsoft.Extensions.Logging HTTP .













, !

, :







services.AddElmah(options =>
{
        options.OnPermissionCheck = context => context.User.Identity.IsAuthenticated;
});
      
      





UseElmah, UseAuthentication UseAuthorization







app.UseAuthentication();
app.UseAuthorization();
app.UseElmah();
      
      





Você pode filtrar os erros registrados usando filtros implementados no código (implementando a interface IErrorFilter) ou no arquivo de configuração xml ( https://elmah.github.io/a/error-filtering/examples/ ).







services.AddElmah<XmlFileErrorLog>(options =>
{
    options.FiltersConfig = "elmah.xml";
    options.Filters.Add(new MyFilter());
})
      
      





Além de registrar o log de erros, a biblioteca permite organizar a distribuição das notificações (via implementação IErrorNotifier), por exemplo, por e-mail.







services.AddElmah<XmlFileErrorLog>(options =>
{
    options.Notifiers.Add(new ErrorMailNotifier("Email",emailOptions));
});
      
      





Espero que esta biblioteca gratuita seja útil em seus projetos.

Mais informações sobre a biblioteca podem ser encontradas aqui .








All Articles