I am just looking at some old code of mine and I have an action filter(OnActionExecuting method)
and at the end of it I have
base.OnActionExecuting(filterContext);
Why searching around I see this quite a few times. I also see that in my old Authorize tag I call the base up.
Should I be always be calling the base methods after?
That will depend on the situation.
For example in authorization filters (deriving from
AuthorizeAttribute
) if you call the base method then all the existing authorization logic built into ASP.NET MVC will be executed. If you don't call it, only your authorization logic will be applied.As far as other standard action filters are concerned (deriving from
ActionFilterAttribute
) all theOnActionExecuting
,OnActionExecuted
,OnResultExecuting
andOnResultExecuted
are defined as virtual but their body is empty, so it doesn't make any difference if you call or not the base method.I believe if you let Visual Studio automatically produce an overriding method by typing
override
and selecting a method in intellisense and pressing tab, Visual Studio will automatically addbase.MethodName()
in the method body.If you don't need it, remove it. I've always removed it when creating my
ActionFilter
s and haven't had a problem yet. The only time you shouldn't remove it is when you need the base method to be called.