在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
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。