Serilog 能否返回结果操作的值而不是数据类型?



我在.net core 2.1 web API中使用Serilog.AspNetCore包。当一个动作被调用时,将记录传入的参数:

[INF] Executing action method WebApi.Controllers.ValuesController.Get (WebApi) with arguments (["4"]) - Validation state: "Valid"

但是当操作完成后,我得到以下不太有用的行:

[INF] Executed action method WebApi.Controllers.ValuesController.Get (WebApi), returned result Microsoft.AspNetCore.Mvc.ObjectResult in 8.2537ms.
[INF] Executing ObjectResult, writing value of type 'System.Collections.Generic.Dictionary`2[[System.String, System.Private.CoreLib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e],[System.String, System.Private.CoreLib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e]]'.

我更喜欢实际值。 例如,字典应该只是 json。

有没有办法覆盖此默认行为?

对于Serilog,它可以返回 json 数据类型,但是,您无法更改Executing ObjectResult的内置返回值。这是由 ObjectResultExecuting 控制的,这是硬代码。

public static void ObjectResultExecuting(this ILogger logger, object value)
{
if (logger.IsEnabled(LogLevel.Information))
{
var type = value == null ? "null" : value.GetType().FullName;
_objectResultExecuting(logger, type, null);
}
}

ObjectResultExecuting记录类型而不是值。我认为这是为了更好的性能。您可以假设如果将响应序列化为字符串,则会浪费大量性能,并且没有必要这样做。

如果您希望记录特定响应,您可以尝试自己登录该方法。

[Produces("application/json")]
[Route("api/[controller]")]
public class SerilogController : Controller
{
private readonly ILogger<SerilogController> _log;
public SerilogController(ILogger<SerilogController> log)
{
_log = log;
}
[HttpGet]
public IEnumerable<string> Get(string password)
{
_log.LogInformation(JsonConvert.SerializeObject(new string[] { "value1", "value2" }));
return new string[] { "value1", "value2" };
}
}

最新更新