So far I\'ve been using Session to pass some variables from one page to another. For instance user role. When a user logs in to the web application the role id of the user i
You forget one thing (I think)
Static data will be the same for all users of the application, while session is "per user".
So for your "User Role" scenario, I would expect funny results ;)
They are two very different things.
Any kind of data can be stored in Session. It then must be casted however.But static fields accept data with the correct datatype only.
It's often helpful to abstract Session values with a helper class. This can improve testability and also allows you to strongly type properties and perform the cast in the internals of the class.
Example:
public List<int> UserRoles
{
get
{
// optionally check that the value is indeed in session, otherwise this
// will throw
return (List<int>)Session["UserRoles"];
}
}
See also:
No, using static variables for this is not the way to go:
Fundamentally, you have two choices for propagating information around your application:
If you can use load-balancing to keep all users going to the same server, and if you don't mind sessions being lost when the AppDomain is recycled1 or a server going down, you can keep it in memory, keyed by session ID... but be careful.
1 There may be mechanisms in ASP.NET to survive this, propagating session information from one AppDomain to another - I'm not sure
Static fields would be shared across all users.
In as web environment, you will have several threads running together.
Updating any static members would need proper concurrency control. Done wrong, this would slow down your site performance significantly.
Sessions can be moved out of process and shared across a web farm.
Out of proc sessions would exist even if your app server crashed.