Как заставить оператор деструктуризации Serilog игнорировать свойства с нулевыми значениями?C#

Место общения программистов C#
Ответить
Anonymous
 Как заставить оператор деструктуризации Serilog игнорировать свойства с нулевыми значениями?

Сообщение Anonymous »

Есть ли способ запретить Serilog сериализовать нулевые свойства объектов, зарегистрированных с помощью оператора @ (деструктуризация)? Я нашел пару сообщений по этой теме (на самом деле я нашел больше, но эти два показались более релевантными с точки зрения вопроса и ответов):
(1) Игнорировать нулевые значения при деструктуризации в Serilog с 2019 года, и единственный ответ предполагает, что это невозможно сделать.
(2) Игнорировать запись нулевых свойств в вывод? также из 2019 года, но предполагает, что может быть способ сделать это с помощью специального ILogEventEnricher, но нет никаких указаний на то, как это сделать на самом деле (это также относится к форматированию json, игнорирующему нулевые свойства, l но я не уверен, относится ли этот пост к объектам форматирования или использованию средства форматирования JSON для создания записей журнала в формате JSON).
В настоящее время мы используем приемник Console Serilog.Templates.ExpressionTemplate, форматтер Serilog.Expressions (мы используем его в сочетании с настраиваемыми расширителями, экранирующими новые строки, поскольку Azure не любит новые строки в записях журнала) и приемник File с форматировщиком по умолчанию. Чтобы игнорировать нулевые значения в выходных данных, мы используем специальный метод расширения ToJson() для сериализации объектов как простых строковых значений (и мы используем JSON.NET):

Код: Выделить всё

public static string? ToJson
(
this object data
)
{
JsonSerializer json = new()
{
// Do not change the following line or it may fail to serialize hierarchical data.
PreserveReferencesHandling = PreserveReferencesHandling.Objects,
NullValueHandling = NullValueHandling.Ignore,
DateFormatString = "yyyy-MM-ddTHH:mm:ss.fffZ",
Formatting = Formatting.None,
ReferenceLoopHandling = ReferenceLoopHandling.Ignore,
TypeNameHandling = TypeNameHandling.None,
};

StringWriter textWriter = new();

json.Serialize(textWriter, data);

return textWriter.ToString();
}
Итак, если у нас есть объект типа:

Код: Выделить всё

{"propA":"valueA","propB":null,"propC":"valueC"}
и мы записываем это как:

Код: Выделить всё

logger.LogDebug("Data: {data}", data.ToJson());
выход будет:

Код: Выделить всё

Data: {"propA":"valueA","propC":"valueC"}
Но если мы регистрируемся так:

Код: Выделить всё

logger.LogDebug("Data: {@data}", data);
выход будет:

Код: Выделить всё

Data: {"propA":"valueA","propB":null,"propC":"valueC"}
Как сделать так, чтобы ведение журнала с помощью оператора @ (деструктуризация) не сериализовало свойства с нулевыми значениями?

Подробнее здесь: https://stackoverflow.com/questions/783 ... ull-values
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»