Категории
Самые читаемые
ChitatKnigi.com » 🟢Компьютеры и Интернет » Базы данных » Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

Читать онлайн Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю
1 ... 589 590 591 592 593 594 595 596 597 ... 642
Перейти на страницу:

Шрифт:

-
+

Интервал:

-
+

Закладка:

Сделать

namespace AutoLot.Services.Logging

{

  public class AppLogging<T> : IAppLogging<T>

  {

    private readonly ILogger<T> _logger;

    private readonly IConfiguration _config;

    private readonly string _applicationName;

    public AppLogging(ILogger<T> logger, IConfiguration config)

    {

      _logger = logger;

      _config = config;

      _applicationName = config.GetValue<string>("ApplicationName");

    }

  }

}

Инфраструктура Serilog позволяет добавлять свойства в стандартный процесс ведения журнала, заталкивая их внутрь LogContext. Добавьте внутренний метод для заталкивания свойств MemberName, FilePath, LineNumber и ApplicationName:

internal List<IDisposable> PushProperties(

  string memberName,

  string sourceFilePath,

  int sourceLineNumber)

{

  List<IDisposable> list = new List<IDisposable>

  {

    LogContext.PushProperty("MemberName", memberName),

    LogContext.PushProperty("FilePath", sourceFilePath),

    LogContext.PushProperty("LineNumber", sourceLineNumber),

    LogContext.PushProperty("ApplicationName", _applicationName)

  };

  return list;

}

Каждая реализация метода следует одному и тому же процессу. На первом шаге вызывается метод PushProperties() для добавления дополнительных свойств и затем соответствующий метод регистрации в журнале, предоставляемый LoggerExtensions в ILogger<T>. Ниже приведены все реализованные методы интерфейса:

public void LogAppError(Exception exception, string message,

  [CallerMemberName] string memberName = "",

  [CallerFilePath] string sourceFilePath = "",

  [CallerLineNumber] int sourceLineNumber = 0)

{

  var list = PushProperties(memberName, sourceFilePath, sourceLineNumber);

  _logger.LogError(exception, message);

(window.adrunTag = window.adrunTag || []).push({v: 1, el: 'adrun-4-390', c: 4, b: 390})

  foreach (var item in list)

  {

    item.Dispose();

  }

}

public void LogAppError(string message,

  [CallerMemberName] string memberName = "",

  [CallerFilePath] string sourceFilePath = "",

  [CallerLineNumber] int sourceLineNumber = 0)

{

  var list = PushProperties(memberName, sourceFilePath, sourceLineNumber);

  _logger.LogError(message);

  foreach (var item in list)

  {

    item.Dispose();

  }

}

public void LogAppCritical(Exception exception, string message,

  [CallerMemberName] string memberName = "",

  [CallerFilePath] string sourceFilePath = "",

  [CallerLineNumber] int sourceLineNumber = 0)

{

  var list = PushProperties(memberName, sourceFilePath, sourceLineNumber);

  _logger.LogCritical(exception, message);

  foreach (var item in list)

  {

    item.Dispose();

  }

}

public void LogAppCritical(string message,

  [CallerMemberName] string memberName = "",

  [CallerFilePath] string sourceFilePath = "",

  [CallerLineNumber] int sourceLineNumber = 0)

{

  var list = PushProperties(memberName, sourceFilePath, sourceLineNumber);

  _logger.LogCritical(message);

  foreach (var item in list)

  {

    item.Dispose();

  }

}

public void LogAppDebug(string message,

  [CallerMemberName] string memberName = "",

  [CallerFilePath] string sourceFilePath = "",

  [CallerLineNumber] int sourceLineNumber = 0)

{

  var list = PushProperties(memberName, sourceFilePath, sourceLineNumber);

1 ... 589 590 591 592 593 594 595 596 597 ... 642
Перейти на страницу:
Отывы о книге
Открыть боковую панель
Комментарии
Руслана
Руслана 17.06.2025 - 12:59
Замечательные рекомендации по подбору персонала 👏
Елизавета
Елизавета 16.05.2025 - 16:36
Осилила только первую страницу, как можно вообще такую муть писать, не видела, случайно, в лифте, не узнала своего босса. Это же детский сад. Все как под копирку, еще застряли в лифте, случайно не
Вита
Вита 25.04.2025 - 18:05
Прекрасная история... Страстная, ненавязчивая, и не длинная
Лена
Лена 27.03.2025 - 03:08
Горячая история 🔥 да и девчонка не простая! Умничка