在WebAPI中,无论如何都要记录使用动作过滤器调用或执行的控制器的动作方法的名称.我正在使用RouteData属性,如下所示,但操作值不包含任何值.有什么办法可以在过滤器中获取操作名称.
public class LogActionFilter : ActionFilterattribute { public override void OnActionExecuted(HttpActionExecutedContext actionExecutedContext) { Log(actionExecutedContext.ActionContext.RequestContext.RouteData); base.OnActionExecuted(actionExecutedContext); } private void Log(System.Web.Http.Routing.IHttpRouteData httpRouteData) { var controllerName = httpRouteData.Values["controller"]; var actionName = httpRouteData.Values["action"]; var message = String.Format("controller:{0},action:{1}",controllerName,actionName); Debug.WriteLine(message,"Action Filter Log"); } }
解决方法
您可以在actionExecutedContext.ActionContext.ActionDescriptor.ActionName属性(字符串)中找到操作名称.
如果您需要的信息多于字符串名称,您还可以将该ActionDescriptor强制转换为ReflectedHttpActionDescriptor并获取所调用的MethodInfo的实例.
var reflectedActionDescriptor = actionExecutedContext.ActionContext.ActionDescriptor as ReflectedHttpActionDescriptor; //inspect reflectedActionDescriptor.MethodInfo here