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

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

Сообщение Anonymous »

Есть ли способ сообщить Serilog не сериализовать нулевые свойства объектов, зарегистрированных с использованием оператора @ (Destructuring)? Я нашел пару постов по этой теме (на самом деле, я нашел больше, но эти два казались более актуальными в отношении вопроса и ответов): < /p>
(1) Игнорируйте нулевые значения, когда разрушение в Serilog происходит из 2019 года, и единственный ответ предполагает, что нет способа сделать это. Также из 2019 года, но это говорит о том, что может быть способ сделать это, используя пользовательский ilogeventenricher , но нет указателей о том, как на самом деле это сделать (это также относится к форматированию форматирования JSON, игнорируя null свойства, но я не уверен, что этот пост относится к форматированию объектов или использование формы JSON для создания входных входов в json в формате json). Console погрузиться в форматер serilog.templates.expressiontemplate, serilog.expressions (мы используем его в сочетании с пользовательскими обогатителями, которые избегают новых строк, потому что Azure не любит новые строки в записях журнала), а файл погружается в форматер по умолчанию. Чтобы игнорировать нулевые значения в выводе, мы используем пользовательский метод расширения 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();
}
< /code>
Итак, если у нас есть объект, подобный: < /p>
{"propA":"valueA","propB":null,"propC":"valueC"}
< /code>
И мы регистрируем его как: < /p>
logger.LogDebug("Data: {data}", data.ToJson());
< /code>
Вывод будет: < /p>
Data: {"propA":"valueA","propC":"valueC"}
< /code>
Но если мы регистрируем как: < /p>
logger.LogDebug("Data: {@data}", data);
< /code>
Вывод будет: < /p>
Data: {"propA":"valueA","propB":null,"propC":"valueC"}
Как мы проводим регистрацию с оператором @ (Destrecructuring), а не сериализуйте свойства с нулевыми значениями?


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

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

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

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

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

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