Tips and Tricks

Implementing Default Behavior in an ASP.NET MVC Controller

If there's something you want to do every time an Action method is called in a Controller, there's an easy way to achieve that. It may even be a best practice.

Every Controller class has a method called OnActionExecuting that runs before any Action method is called (there's also an OnActionExecuted that runs after any Action method). If you wanted to implement some logging code to keep track of a Controller's behavior, OnActionExecuting would be a great place to put your logging code:

Public Class HomeController
  Inherits System.Web.Mvc.Controller

  Protected Overrides Sub OnActionExecuting(filterContext As ActionExecutingContext)
    '... logging code ...
  End Sub

Of course, if you wanted to apply this code on only some methods in some controllers, you could create an Action Filter. But what if you wanted to apply this code to every action method in every controller? You have two choices.

You could, of course, create an Action Filter and apply it through the GlobalFilterCollection in the FilterConfig class in your application's App_Start folder. Or you could create a base Controller class to hold the method:

Public Class ControllerBase
  Inherits System.Web.Mvc.Controller

  Protected Overrides Sub OnActionExecuting(filterContext As ActionExecutingContext)
  End Sub

End Class

And then have all your other controllers inherit from your new base Controller class:

Public Class HomeController
  Inherits ControllerBase

Personally, I think it's a good idea to have your own base class for your Controllers. You may not need it yet, but when you do have some code you want to share with all your Controllers, you'll be glad that base class exists.

About the Author

Peter Vogel is a system architect and principal in PH&V Information Services. PH&V provides full-stack consulting from UX design through object modeling to database design. Peter tweets about his VSM columns with the hashtag #vogelarticles. His blog posts on user experience design can be found at

comments powered by Disqus


  • AI for GitHub Collaboration? Maybe Not So Much

    No doubt GitHub Copilot has been a boon for developers, but AI might not be the best tool for collaboration, according to developers weighing in on a recent social media post from the GitHub team.

  • Visual Studio 2022 Getting VS Code 'Command Palette' Equivalent

    As any Visual Studio Code user knows, the editor's command palette is a powerful tool for getting things done quickly, without having to navigate through menus and dialogs. Now, we learn how an equivalent is coming for Microsoft's flagship Visual Studio IDE, invoked by the same familiar Ctrl+Shift+P keyboard shortcut.

  • .NET 9 Preview 3: 'I've Been Waiting 9 Years for This API!'

    Microsoft's third preview of .NET 9 sees a lot of minor tweaks and fixes with no earth-shaking new functionality, but little things can be important to individual developers.

  • Data Anomaly Detection Using a Neural Autoencoder with C#

    Dr. James McCaffrey of Microsoft Research tackles the process of examining a set of source data to find data items that are different in some way from the majority of the source items.

  • What's New for Python, Java in Visual Studio Code

    Microsoft announced March 2024 updates to its Python and Java extensions for Visual Studio Code, the open source-based, cross-platform code editor that has repeatedly been named the No. 1 tool in major development surveys.

Subscribe on YouTube