Partilhar via


SessionStateUtility.GetHttpSessionStateFromContext(HttpContext) Método

Definição

Recupera dados da sessão do contexto da solicitação 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

O HttpContext do qual recuperar dados da sessão.

Retornos

Uma instância de implementação IHttpSessionState preenchida com os dados da sessão da solicitação atual.

Exemplos

O exemplo de código a seguir mostra o manipulador do ReleaseRequestState evento em um módulo de estado de sessão personalizado. O módulo recupera dados de sessão do HttpContext para a solicitação 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

Comentários

O GetHttpSessionStateFromContext método pode ser usado por um módulo de estado de sessão para recuperar dados de sessão da solicitação atual. Isso ocorre durante o ReleaseRequestState evento no final de uma solicitação. Os dados de sessão retornados podem ser gravados no armazenamento de dados da sessão. Se a sessão tiver sido abandonada, os dados da sessão poderão ser removidos do armazenamento de dados e HttpContexte o evento Session_OnEnd poderá ser executado.

Notas aos Herdeiros

Você pode usar o RemoveHttpSessionStateFromContext(HttpContext) método para remover dados de sessão do repositório interno e o RaiseSessionEnd(IHttpSessionState, Object, EventArgs) método para acionar o Session_OnEnd evento.

Aplica-se a