【发布时间】:2018-01-10 18:09:47
【问题描述】:
我希望自动记录每个请求。在之前的 .Net Framwork WebAPI 项目中,我曾经注册了一个 delegateHandler 来实现。
WebApiConfig.cs
public static void Register(HttpConfiguration config)
{
config.MessageHandlers.Add(new AutoLogDelegateHandler());
}
AutoLogDelegateHandler.cs
public class AutoLogDelegateHandler : DelegatingHandler
{
protected override async Task<HttpResponseMessage> SendAsync(HttpRequestMessage request, CancellationToken cancellationToken)
{
var requestBody = request.Content.ReadAsStringAsync().Result;
return await base.SendAsync(request, cancellationToken)
.ContinueWith(task =>
{
HttpResponseMessage response = task.Result;
//Log use log4net
_LogHandle(request, requestBody, response);
return response;
});
}
}
日志内容示例:
------------------------------------------------------
2017-08-02 19:34:58,840
uri: /emp/register
body: {
"timeStamp": 1481013427,
"id": "0322654451",
"type": "t3",
"remark": "system auto reg"
}
response: {"msg":"c556f652fc52f94af081a130dc627433","success":"true"}
------------------------------------------------------
但在.NET Core WebAPI项目中,没有WebApiConfig,或者Global.asaxGlobalConfiguration.Configure(WebApiConfig.Register);处的注册功能
那么有什么方法可以在 .NET Core WebAPI 中实现这一点吗?
【问题讨论】:
标签: c# asp.net-web-api asp.net-core .net-core log4net