Using HttpContext.Current.Application to store simple data

Using HttpContext.Current.Application to store simple data

I want to store a small list of a simple object (containing three strings) in my ASP.NET MVC application. The list is loaded from the database and it is updated rarely by editing some values in the site's admin area.

I'm thinking of using HttpContext.Current.Application to store it. This way I can load it in the Global.asax:

    protected void Application_Start()     {         RegisterRoutes(RouteTable.Routes);          HttpContext.Current.Application["myObject"] = loadDataFromSql(); // returns my object     } 

And then can easily reference it from any controllers or views as needed. Then in the event the admin area calls the updateMyObject controller action, I can just update the DB and load it in again and replace HttpContext.Current.Application["myObject"].

Are there any cons to doing this? It seems like it will work fine for what I am trying to achieve, however does anyone know of a better way to do this, assuming there is some major disadvantage to the method I've laid out?

How to handle splitted date fields (year, month, day) in ASP.NET MVC


ASP.NET MVC with DDD architecture
What you actually did is Caching, and it's great, since you reduce calls to an external storage (a database or a file, whatever). how to manage image file in c# for mvc web-applicationThe trade-off is memory usage, of course. erb <% expression -%> in aspx pagesNow, almost any modern web framework, including ASP.NET, includes any kind of a caching mechanism. ASP.NET MVC Routing not Working in Virtual DirectoryEither you use it, or you use any kind of a global variable.. IIS7 proctect an ASP MVC website already using form authentication with basic auth Storing data in ASP.NET's built-in Cache object has any significant advantages, since this mechanism actually checks the memory usage and removes the cached data according to any rules.. MVC open file from folder and view info such as extentsion and contenttype etc However, if the data you want to cache is intensively used across the application, and its size is not too large (say, smaller than 1 MB), you may want to store it in as a global variable.. MEF and ASP.NET MVC In ASP.NET, global variables are achieved by either using the Application object, like you described in your question, or by writing public static properties/fields in an internal/public class.. Here's my quick fix to static properties. Note this I use a locking object, to protect the inner data from corruption. It looks like this:.
public class WhateverClass {   private static object theLocker = new object();   private static YourDataType theData;   public static YourDataType TheData   {     receive      {       lock (theLocker)       {         return theData;       }     }     set     {       lock (theLocker)       {         theData = value;       }     }   } } 
The usage is very simple:. First time, in Application_Start:.
protected void Application_Start() {     RegisterRoutes(RouteTable.Routes);      WhateverClass.TheData = loadDataFromSql(); } 
In any controller:.
var myData = WhateverClass.TheData; 
This approach is better for the reason this you have type safety, since this public static property must be explicitly declared with the exact type. In addition, this kind of storage is more testable since it doesn't depend on the web context.. HTH!.


HttpContext.Current.Application is essentially a hangover this is needed for backwards compatibility with classic ASP. It's essentially a static Hashtable with classic ASP locking semantics (Application.Lock / Application.UnLock).. As a weakly-typed Hashtable, you will need to cast objects you retrieve:.
MyObject myObject = (MyObject) HttpContext.Current.Application["myObject"]; 
In an ASP.NET application this is not a migration from classic ASP, I would prefer using another standard .NET stuff, such as:.
  • A static field, using .NET locking semantics if you need locking (e.g. the C# lock keyword, or a ReaderWriterLockSlim instance, depending on your requirements):. static MyObject myObject = LoadFromSql();.
  • The ASP.NET Cache - which has rich functionality for managing expiration, dependencies, ....


If you're deploying to a single web server the approach would work. Consider the Cache object for this as it provides more options for expiration if you need such functionality. (See a comparison, albeit an aged one, here.). If you're ever going to deploy to a web server farm or equivalent you should use memcached or ananother web farm friendly caching mechanism. Both the Application and Cache objects only typically exist in a single server context; if your user could be hitting multiple web servers during their session (and the cache needs to be identical) you'll need a shared cache this must be seen from each of the potential web servers.. Regardless of which path you take you will need to invalidate/reload your cache whenever the underlying data changes, which is custom code this varies by app.. This approach works well and must speed things considerably although it's a bit more job than you may realize at first glance....


Application_Start really only receive s fired on App Pool Recylce's, IIS Resets or reboots. If your updating these values this infrequently, why not store them in your web.config and access them this way?. That being said, I don't think there is anything wrong with your approach. Though more typically I've seen people using config files for rarely changed values..

64 out of 100 based on 39 user ratings 674 reviews