SessionStateUtility.GetHttpSessionStateFromContext(HttpContext) Método
Definição
Importante
Algumas informações dizem respeito a um produto pré-lançado que pode ser substancialmente modificado antes de ser lançado. A Microsoft não faz garantias, de forma expressa ou implícita, em relação à informação aqui apresentada.
Recupera os dados da sessão do contexto para o pedido atual.
public:
static System::Web::SessionState::IHttpSessionState ^ GetHttpSessionStateFromContext(System::Web::HttpContext ^ context);
public static System.Web.SessionState.IHttpSessionState GetHttpSessionStateFromContext(System.Web.HttpContext context);
static member GetHttpSessionStateFromContext : System.Web.HttpContext -> System.Web.SessionState.IHttpSessionState
Public Shared Function GetHttpSessionStateFromContext (context As HttpContext) As IHttpSessionState
Parâmetros
- context
- HttpContext
A HttpContext partir da qual recuperar os dados da sessão.
Devoluções
Uma IHttpSessionState instância de implementação preenchida com dados de sessão do pedido atual.
Exemplos
O exemplo de código seguinte mostra o handler do ReleaseRequestState evento num módulo de estado de sessão personalizado. O módulo recupera os dados HttpContext da sessão do pedido atual usando o GetHttpSessionStateFromContext método. Este exemplo de código faz parte de um exemplo maior fornecido para a SessionStateUtility classe.
//
// Event handler for HttpApplication.ReleaseRequestState
//
private void OnReleaseRequestState(object source, EventArgs args)
{
HttpApplication app = (HttpApplication)source;
HttpContext context = app.Context;
string sessionID;
// Read the session state from the context
HttpSessionStateContainer stateProvider =
(HttpSessionStateContainer)(SessionStateUtility.GetHttpSessionStateFromContext(context));
// If Session.Abandon() was called, remove the session data from the local Hashtable
// and execute the Session_OnEnd event from the Global.asax file.
if (stateProvider.IsAbandoned)
{
try
{
pHashtableLock.AcquireWriterLock(Int32.MaxValue);
sessionID = pSessionIDManager.GetSessionID(context);
pSessionItems.Remove(sessionID);
}
finally
{
pHashtableLock.ReleaseWriterLock();
}
SessionStateUtility.RaiseSessionEnd(stateProvider, this, EventArgs.Empty);
}
SessionStateUtility.RemoveHttpSessionStateFromContext(context);
}
'
' Event handler for HttpApplication.ReleaseRequestState
'
Private Sub OnReleaseRequestState(ByVal [source] As Object, ByVal args As EventArgs)
Dim app As HttpApplication = CType([source], HttpApplication)
Dim context As HttpContext = app.Context
Dim sessionID As String
' Read the session state from the context
Dim stateProvider As HttpSessionStateContainer = _
CType(SessionStateUtility.GetHttpSessionStateFromContext(context), HttpSessionStateContainer)
' If Session.Abandon() was called, remove the session data from the local Hashtable
' and execute the Session_OnEnd event from the Global.asax file.
If stateProvider.IsAbandoned Then
Try
pHashtableLock.AcquireWriterLock(Int32.MaxValue)
sessionID = pSessionIDManager.GetSessionID(context)
pSessionItems.Remove(sessionID)
Finally
pHashtableLock.ReleaseWriterLock()
End Try
SessionStateUtility.RaiseSessionEnd(stateProvider, Me, EventArgs.Empty)
End If
SessionStateUtility.RemoveHttpSessionStateFromContext(context)
End Sub
Observações
O GetHttpSessionStateFromContext método pode ser usado por um módulo de estado de sessão para recuperar dados de sessão do pedido atual. Isto ocorre durante o ReleaseRequestState evento no final de um pedido. Os dados de sessão devolvidos podem então ser escritos no armazenamento de dados da sessão. Se a sessão tiver sido abandonada, os dados da sessão podem ser removidos do armazenamento de dados e HttpContext, e o evento Session_OnEnd pode ser executado.
Notas para Herdeiros
Pode usar o RemoveHttpSessionStateFromContext(HttpContext) método para remover dados de sessão do armazenamento interno e o RaiseSessionEnd(IHttpSessionState, Object, EventArgs) método para gerar o Session_OnEnd evento.