首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >.NET Web添加日志

.NET Web添加日志
EN

Stack Overflow用户
提问于 2014-06-20 00:01:22
回答 1查看 8.8K关注 0票数 3

我正在寻找一些关于处理API日志记录的最佳方法的帮助。如果这是最好的方式,我想记录对sql或文本文件的所有请求和响应。目前,我一直在向Server中的日志表中插入一行。我使用一个名为LogAction的静态方法来实现这一点,并且在Web中的每个Controller的末尾运行它。我还记录了被捕获的异常。有什么方法可以用MVC Web来实现这一点呢?还是我走在正确的轨道上?

目前的情况如下:

代码语言:javascript
运行
复制
// 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操作的最有效方法是什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-06-20 01:47:39

对于记录对API操作的调用,我使用了一个自定义属性,如下所示:

代码语言:javascript
运行
复制
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控制器:

代码语言:javascript
运行
复制
[LogApiRequest]
public void Post(SomeThingInputModel thing)
{
    // Controller code
    ...
}
票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24318061

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档