Meine WebApi-Filtermethode OnActionExecuted
wird zweimal aufgerufen. Mein Filter (ich mache es so einfach wie möglich):WebApi Aktionsfilter zweimal aufgerufen
public class NHibernateActionFilter : ActionFilterAttribute
{
// [Inject]
// public ISessionFactoryProvider sessionFactoryProvider { get; set; }
public override void OnActionExecuted(HttpActionExecutedContext actionExecutedContext)
{
var a = 5;
var b = a;
//new BaseSessionProvider(sessionFactoryProvider).EndContextSession();
}
}
Mein Setup:
protected void Application_Start()
{
AreaRegistration.RegisterAllAreas();
WebApiConfig.Register(GlobalConfiguration.Configuration);
//http://stackoverflow.com/questions/9521040/how-to-add-global-asp-net-web-api-filters
FilterConfig.RegisterWebApiFilters(GlobalConfiguration.Configuration.Filters);
}
public class FilterConfig
{
public static void RegisterWebApiFilters(System.Web.Http.Filters.HttpFilterCollection filters)
{
filters.Add(new NHibernateActionFilter());
}
}
In Debugger I OnActionExecuted
zweimal mit dem gleichen actionExecutedContext
fangen. Warum?
UPD
Controller
public class BankSmsController : ApiController
{
[AcceptVerbs(HttpVerbs.Get)]
public int GetTest()
{
return 1;
}
}
Ich bemerkte, dass ein "Inject" -Attribut auskommentiert wurde - könnte es eine NInject-Konfiguration geben, die auch Filter einrichtet, so dass sie zweimal hinzugefügt wird? Haben Sie bestätigt, dass nur eine Instanz des Filters in der globalen Filtersammlung vorhanden ist, nachdem der Startup-Code vollständig ausgeführt wurde? – levelnis
Kein Ninject überhaupt. Ich entferne 'kernel.BindFilter (FilterScope.Global, 1);' –
können Sie den Controller anzeigen? –