(Actualizado para completar)
Puede acceder a las variables de sesión desde cualquier página o control usando Session["loginId"]
y desde cualquier clase (por ejemplo, desde dentro de una biblioteca de clases), usandoSystem.Web.HttpContext.Current.Session["loginId"].
Pero sigue leyendo para obtener mi respuesta original ...
Siempre uso una clase contenedora alrededor de la sesión ASP.NET para simplificar el acceso a las variables de sesión:
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; }
}
Esta clase almacena una instancia de sí misma en la sesión ASP.NET y le permite acceder a las propiedades de su sesión de forma segura desde cualquier clase, por ejemplo, así:
int loginId = MySession.Current.LoginId;
string property1 = MySession.Current.Property1;
MySession.Current.Property1 = newValue;
DateTime myDate = MySession.Current.MyDate;
MySession.Current.MyDate = DateTime.Now;
Este enfoque tiene varias ventajas:
- te salva de muchos tipos de fundición
- no tiene que usar claves de sesión codificadas en toda su aplicación (por ejemplo, Sesión ["loginId"]
- puede documentar los elementos de su sesión agregando comentarios de documentos XML en las propiedades de MySession
- puede inicializar sus variables de sesión con valores predeterminados (por ejemplo, asegurarse de que no sean nulos)