本文整理汇总了C#中LogLevel.ToSerilogEventLevel方法的典型用法代码示例。如果您正苦于以下问题:C# LogLevel.ToSerilogEventLevel方法的具体用法?C# LogLevel.ToSerilogEventLevel怎么用?C# LogLevel.ToSerilogEventLevel使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类LogLevel
的用法示例。
在下文中一共展示了LogLevel.ToSerilogEventLevel方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: Write
protected void Write(LogLevel level, Exception exception, object message)
{
try
{
// If message is a string, try to deserialize if it might be a JSON object.
// If that goes wrong, simply log it as a string.
//
// This is very useful, because Common.Logging implementations for other logging packages
// often do not support logging objects - when given an object, they just log the name of the object.
// By including this conversion, software trying to log objects via Common.Logging can
// serialise those objects into a JSON string and log that string, knowing that if
// Common.Logging.Serilog is used, the object will still be logged in a structured manner.
if (message is string)
{
string messageString = (string)message;
if (messageString.TrimStart().StartsWith("{"))
{
var js = new JavaScriptSerializer();
message = js.Deserialize<Dictionary<string, Object>>(messageString);
_logger.Write(level.ToSerilogEventLevel(), exception, "{@Message:l}", message);
}
else
{
_logger.Write(level.ToSerilogEventLevel(), exception, "{Message:l}", message.ToString());
}
}
else
{
_logger.Write(level.ToSerilogEventLevel(), exception, "{@Message}", message);
}
}
catch
{
_logger.Write(level.ToSerilogEventLevel(), exception, "{Message:l}", message.ToString());
}
}
示例2: WriteFormat
protected void WriteFormat(
LogLevel level,
Exception exception,
IFormatProvider formatProvider,
string message,
object[] parameters)
{
if (formatProvider == null)
{
// check for non-value types and enable deconstruction on them...
List<KeyValuePair<string, string>> replaceParameters =
parameters.Select((p, i) => new { Param = p, Index = i })
.Where(p => p != null && !p.GetType().IsValueType)
.Select(
p =>
new KeyValuePair<string, string>(string.Format("{{{0}}}", p.Index),
string.Format("{{@{0}}}", p.Index)))
.ToList();
// replace format strings {0} with {@0}.
// not very fast, but simple at least.
message = replaceParameters.Aggregate(message,
(current, replace) => current.Replace(replace.Key, replace.Value));
_logger.Write(level.ToSerilogEventLevel(), exception, message, parameters);
}
else
Write(level, exception, string.Format(formatProvider, message, parameters));
}
示例3: Write
protected void Write(LogLevel level, Exception exception, object message)
{
if (message is string)
_logger.Write(level.ToSerilogEventLevel(), exception, "{Message:l}", message.ToString());
else
_logger.Write(level.ToSerilogEventLevel(), exception, "{@Message}", message);
}