微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

asp.net-web-api – 如何记录webapi中控制器中执行的操作方法

在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 举报,一经查实,本站将立刻删除。

相关推荐