如何在 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 特性,因此日志信息将被添加到调试控制台。

广告
数据结构
网络
RDBMS
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP