How can I get the value of a session variable inside a static method?
Solution 1
HttpContext.Current.Session["..."]
HttpContext.Current
gets you the current ... well, Http Context; from which you can access: Session, Request, Response etc
Solution 2
If you haven't changed thread, you can use HttpContext.Current.Session
, as indicated by jwwishart.
HttpContext.Current
returns the context associated with the thread. Obviously this means you can't use it if you've started a new thread, for example. You may also need to consider thread agility - ASP.NET requests don't always execute on the same thread for the whole of the request. I believe that the context is propagated appropriately, but it's something to bear in mind.
Solution 3
Try this:
HttpContext.Current.Session["UserName"].ToString();
Solution 4
You can access the current Session
via HttpContext.Current
- a static property through which you can retrieve the HttpContext
instance that applies to the current web request. This is a common pattern in static App Code and static page methods.
string s = (string)HttpContext.Current.Session["UserName"];
The same technique is used to access the Session
from within ASMX web methods decorated with [WebMethod(EnableSession = true)]
because whilst such methods are not static they do not inherit from Page
and thus do not have direct access to a Session
property.
Static code can access the Application Cache in the same way:
string var1 = (string)HttpContext.Current.Cache["Var1"];
If the static code is inside another project we need to reference System.Web.dll
. However, in this case it is generally best to avoid such a dependency because if the code is called from outside of an ASP.NET context HttpContext.Current
will be null
, for obvious reasons. Instead, we can require a HttpSessionState
as an argument (we'll still need the reference to System.Web
of course):
public static class SomeLibraryClass
{
public static string SomeLibraryFunction(HttpSessionState session)
{
...
}
}
Call:
[WebMethod]
public static string GetName()
{
return SomeLibraryClass.SomeLibraryFunction(HttpContext.Current.Session);
}
ACP
Updated on March 12, 2020Comments
-
ACP about 4 years
I am using ASP.NET page methods with jQuery.... How do I get the value of a session variable inside a static method in C#?
protected void Page_Load(object sender, EventArgs e) { Session["UserName"] = "Pandiya"; } [WebMethod] public static string GetName() { string s = Session["UserName"].ToString(); return s; }
When I compile this I get the error:
An object reference is required for the non-static field, method, or property 'System.Web.UI.Page.Session.get'`
-
jwwishart about 14 yearsHttpContext.Current gives you access to the current Http Context as explained in the edit i just did. The HttpContext.Current property is static (msdn.microsoft.com/en-us/library/…) and it does it's magic and returns you the current HttpContext. You should have access to most of the stuff you have access in the code behind etc.
-
jwwishart about 14 yearsP.S. You were trying to access a non-static property (Session property) via a static method... obviously it(the Session property) exists only on an instance of the class! Hope this explains things better?
-
P Daddy about 14 years@Pandiya Chendur:
Session
is a instance property of the Page class that returns anHttpSessionState
object. When you write something likeSession["..."]
, this is reallythis.Session["..."]
. Because a static member has nothis
object, you can't access theSession
property. You can, however, access the sameHttpSessionState
object using the code that hwwishart suggested. -
P Daddy about 14 years@jwwishart: Sorry for mistyping your name in the previous comment. J and H are right next to each other and the room is dark at the moment.
-
Raghav over 12 yearsHow can we use the Page, Application etc in static method,
-
Stephen Kennedy about 6 yearsSessionState works with page methods and I believe your concerns are not valid Jon (other than if a new thread is started by our own code, I don't know what happens then). I'd be more nervous of your unqualified suggestion that "Ideally you should pass all the information you need from the client instead" as that very much depends on the nature of the data - I have seen some very dangerous examples in the wild! I'd rather say "it depends".
-
Jon Skeet about 6 years@StephenKennedy: I've removed the last paragraph entirely rather than spending ages adding nuance for a nearly-8-year-old answer.