Ich bin neu in der ganzen MVC-Sache und betrachte die Re-Implementierung einiger WCF-Dienste mit ASP.NET Web API. Als Teil davon würde ich gerne einen Aktionsfilter implementieren, der alle Aktionen und Ausnahmen protokolliert sowie das Timing, so dass ich dachte, ich würde mit einem Aktionsfilter beginnen, der Filter wird jedoch nicht aufgerufen.ASP.NET-Web-API ActionFilter-Beispiel
public class MyTrackingActionFilter : ActionFilterAttribute, IExceptionFilter
{
private Stopwatch stopwatch = new Stopwatch();
public void OnException(ExceptionContext filterContext)
{
...
}
public override void OnActionExecuted(ActionExecutedContext filterContext)
{
...
}
public override void OnActionExecuting(ActionExecutingContext filterContext)
{
this.stopwatch.Start();
Trace.TraceInformation(" Entering {0}", filterContext.RouteData);
}
}
und auf dem Controller, ich habe
[MyTrackingActionFilter]
public class MyResourceController : ApiController
{
...
}
Die Routen-Setup in Global.asax verwenden Anrufe wie:
var routeTemplate = ...
var defaults = new { controller = controllerName, action = methodName };
var constraints = new { httpMethod = new HttpMethodConstraint(myHTTPMethods.Split(',')) };
routes.MapHttpRoute(methodName, routeTemplate, defaults, constraints);
Das Problem ist, dass die Aktionen auf dem MyResourceController werden wie erwartet aufgerufen und erfolgreich ausgeführt. Der Client kann den Server nach den erforderlichen Informationen abfragen, und alles verhält sich gut, außer dass keine der Aktionsfiltermethoden jemals aufgerufen wird.
Mein Verständnis war, dass der Rest "automatisch" passiert ist. Das ist eindeutig nicht genug - Irgendwelche Vorschläge, was falsch ist? Muss ich diese irgendwo registrieren?
HINWEIS: Ich habe versucht, das Attribut sowohl der Operation als auch der Klasse hinzuzufügen und keine der beiden Möglichkeiten. – WildeButNotOscar
BE 100% sicher sein, dass die mit API Controller verbundenen Klassen den ActionFilter von System.Web.HttpFilters verwenden und NICHT den von System.Web.Mvc –
. Oben sollten Sie etwas sehen wie: using System.Web.HttpFilters; –