(Обновлено для полноты)
Вы можете получить доступ к переменным сеанса с любой страницы или элемента управления, используяSession["loginId"]
и из любого класса (например, из библиотеки классов), используяSystem.Web.HttpContext.Current.Session["loginId"].
Но, пожалуйста, читайте мой оригинальный ответ ...
Я всегда использую класс-оболочку вокруг сеанса ASP.NET, чтобы упростить доступ к переменным сеанса:
public class MySession
{
// private constructor
private MySession()
{
Property1 = "default value";
}
// Gets the current session.
public static MySession Current
{
get
{
MySession session =
(MySession)HttpContext.Current.Session["__MySession__"];
if (session == null)
{
session = new MySession();
HttpContext.Current.Session["__MySession__"] = session;
}
return session;
}
}
// **** add your session properties here, e.g like this:
public string Property1 { get; set; }
public DateTime MyDate { get; set; }
public int LoginId { get; set; }
}
Этот класс хранит один свой экземпляр в сеансе ASP.NET и позволяет вам обращаться к свойствам сеанса безопасным для типов способом из любого класса, например, так:
int loginId = MySession.Current.LoginId;
string property1 = MySession.Current.Property1;
MySession.Current.Property1 = newValue;
DateTime myDate = MySession.Current.MyDate;
MySession.Current.MyDate = DateTime.Now;
Этот подход имеет несколько преимуществ:
- это спасает вас от большого количества кастинга
- вам не нужно использовать жестко закодированные сеансовые ключи во всем приложении (например, Session ["loginId"]).
- вы можете задокументировать элементы вашего сеанса, добавив XML-комментарии к документу о свойствах MySession
- вы можете инициализировать переменные сеанса значениями по умолчанию (например, убедившись, что они не равны NULL)