如何在 C# ASP.NET WebAPI 中为记录目的创建日志筛选器?


操作筛选器用于在操作方法执行之前或之后添加额外的逻辑。OnActionExecuting 和 OnActionExecuted 方法用于在操作方法执行之前或之后添加逻辑。

让我们创建一个实现记录一些操作方法执行前后信息的操作筛选器 LogAttribute。

LogAttribute

示例

using System;
using System.Diagnostics;
using System.Web.Http.Controllers;
using System.Web.Http.Filters;
namespace DemoWebApplication.Controllers{
   public class LogAttribute : ActionFilterAttribute {
      public override void OnActionExecuting(HttpActionContext actionContext){
         Debug.WriteLine(string.Format("Action Method {0} executing at {1}",
            actionContext.ActionDescriptor.ActionName, DateTime.Now.ToShortDateString()),
            "Web API Logs");
      }
      public override void OnActionExecuted(HttpActionExecutedContext
      actionExecutedContext){
         Debug.WriteLine(string.Format("Action Method {0} executed at {1}",
         actionExecutedContext.ActionContext.ActionDescriptor.ActionName,
         DateTime.Now.ToShortDateString()), "Web API Logs");
      }
   }
}

控制器操作

示例

using System.Web.Http;
namespace DemoWebApplication.Controllers{
   public class DemoController : ApiController{
      [Log]
      public IHttpActionResult Get(){
         //Some logic
         return Ok();
      }
   }
}

由于我们使用了具有 OnActionExecuting 和 OnActionExecuted 方法实现的 Log 特性,因此日志信息将被添加到调试控制台。


更新于:2020 年 8 月 19 日

1K+ 次浏览

事业起步

完成课程并获得认证

开始操作
广告
© . All rights reserved.