我希望自動記錄每個請求。在之前的.Net Framwork WebAPI項目中,我曾經註冊過一個delegateHandler來完成這個任務。如何在.NET Core WebAPI中自動記錄每個請求?
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核心的WebAPI項目,沒有WebApiConfig
,或Global.asax的註冊功能GlobalConfiguration.Configure(WebApiConfig.Register);
那麼有沒有什麼辦法可以在.NET Core WebAPI中實現這一點?
是的,它的工作原理。我創建了一個'AutoLogAttribute',並在'OnActionExecuted'處記錄了每個請求。然後通過將它添加到Startup類中的ConfigureServices方法中的MvcOptions.Filters集合來全局註冊該過濾器。 – wtf512
真棒,我很高興它的作品 – Eedoh
正確的答案是,它已經記錄了你。 – davidfowl