(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
Мобильная версия