gpt4 book ai didi

c# - .NET Web API - 添加日志记录

转载 作者:行者123 更新时间:2023-11-30 15:29:12 25 4
gpt4 key购买 nike

我正在寻求有关处理 API 日志记录的最佳方式的帮助。如果这是最好的方法,我想记录所有对 sql 或文本文件的请求和响应。目前我一直在 SQL Server 的日志表中插入一行。我使用名为 LogAction 的静态方法来执行此操作,并在我的 Web API 中的每个 Controller 的末尾附近运行它。我还记录了被捕获的异常。有没有办法在本地使用 MVC Web API 执行此操作,或者我走在正确的轨道上?

目前它看起来像这样:

// Log API Call
System.Xml.Serialization.XmlSerializer x = new System.Xml.Serialization.XmlSerializer(request.GetType());
StringWriter s = new StringWriter();
x.Serialize(s, request);
Utilities.LogAction(Utilities.LogType.MAIN, false, response.ToString(), s.ToString(), "MainController: Successful");

有没有办法让它在本地记录所有 API 操作?这对我来说感觉不对,因为如果这个静态方法和实际返回响应之间发生了什么,那么这个日志就不再有效。记录 API 操作的最有效方法是什么?

最佳答案

为了记录对 API 操作的调用,我使用了如下自定义属性:

public class LogApiRequestAttribute : System.Web.Http.Filters.ActionFilterAttribute
{
/// <summary>
/// For Web API controllers
/// </summary>
/// <param name="actionExecutedContext"></param>
public override void OnActionExecuted(HttpActionExecutedContext actionExecutedContext)
{
base.OnActionExecuted(actionExecutedContext);

var request = actionExecutedContext.Request;
var response = actionExecutedContext.Response;
var actionContext = actionExecutedContext.ActionContext;

// Log API Call
...
}
}

您可能需要检查 actionExecutedContext 以查看它是否具有您想要的请求和响应信息。您可能想要替代或同时重写 OnActionExecuting 方法。

然后使用以下属性装饰您的 Web API Controller :

[LogApiRequest]
public void Post(SomeThingInputModel thing)
{
// Controller code
...
}

关于c# - .NET Web API - 添加日志记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24318061/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com