SessionIDManager.CreateSessionID(HttpContext) Metodo

Definizione

Crea un identificatore di sessione univoco per la sessione.

public:
 virtual System::String ^ CreateSessionID(System::Web::HttpContext ^ context);
public virtual string CreateSessionID(System.Web.HttpContext context);
abstract member CreateSessionID : System.Web.HttpContext -> string
override this.CreateSessionID : System.Web.HttpContext -> string
Public Overridable Function CreateSessionID (context As HttpContext) As String

Parametri

context
HttpContext

Oggetto corrente HttpContext che fa riferimento agli oggetti server utilizzati per elaborare le richieste HTTP, ad esempio le Request proprietà e Response .

Valori restituiti

Identificatore di sessione univoco.

Implementazioni

Esempio

Nell'esempio di codice seguente viene illustrata una classe che eredita la classe ed esegue l'override SessionIDManager dei CreateSessionID metodi e Validate con metodi che forniscono e convalidano un Guid oggetto come SessionID.

using System;
using System.Configuration;
using System.Web.Configuration;
using System.Web;
using System.Web.SessionState;

namespace Samples.AspNet.Session
{

  public class GuidSessionIDManager : SessionIDManager
  {

    public override string CreateSessionID(HttpContext context)
    {
      return Guid.NewGuid().ToString();
    }

    public override bool Validate(string id)
    {
      try
      {
        Guid testGuid = new Guid(id);

        if (id == testGuid.ToString())
          return true;
      }
      catch
      {
      }

      return false;
    }
  }
}
Imports System.Configuration
Imports System.Web.Configuration
Imports System.Web
Imports System.Web.SessionState


Namespace Samples.AspNet.Session

  Public Class GuidSessionIDManager
    Inherits SessionIDManager

    Public Overrides Function CreateSessionID(context As HttpContext) As String
      Return Guid.NewGuid().ToString()
    End Function

    Public Overrides Function Validate(id As String) As Boolean
      Try
        Dim testGuid As Guid = New Guid(id)

        If id = testGuid.ToString() Then _
          Return True
      Catch
      
      End Try

      Return False
    End Function

  End Class

End Namespace

Per usare la classe personalizzata illustrata in questo esempio, configurare l'attributo sessionIDManagerType dell'elemento sessionState (schema ASP.NET Settings), come illustrato nell'esempio seguente.

<sessionState
  Mode="InProc"
  stateConnectionString="tcp=127.0.0.1:42424"
  stateNetworkTimeout="10"
  sqlConnectionString="data source=127.0.0.1;Integrated Security=SSPI"
  sqlCommandTimeout="30"
  customProvider=""
  cookieless="false"
  regenerateExpiredSessionId="false"
  timeout="20"
  sessionIDManagerType="Your.ID.Manager.Type,
    CustomAssemblyNameInBinFolder"
/>

Commenti

Questo metodo non deve essere chiamato dal codice dell'applicazione.

Il CreateSessionID metodo restituisce un identificatore di sessione univoco che è un numero generato in modo casuale codificato in una stringa di 24 caratteri costituita da caratteri minuscoli da a z e numeri da 0 a 5.

Note per gli eredi

È possibile specificare un identificatore di sessione personalizzato da usare ASP.NET stato sessione creando una classe che eredita la classe SessionIDManager ed eseguendo l'override dei metodi CreateSessionID(HttpContext) e Validate(String) con le proprie implementazioni personalizzate. Se l'ID sessione personalizzato non soddisfa i vincoli di carattere applicati dall'implementazione predefinita del Validate(String) metodo , è necessario eseguire l'override del metodo per fornire la Validate(String) convalida dell'identificatore di sessione personalizzato. In questo caso, la classe garantirà che l'identificatore SessionIDManager di sessione personalizzato sia codificato rispettivamente nella risposta HTTP e nell'URL decodificato dalla richiesta HTTP usando i Encode(String) metodi e Decode(String) .

Si applica a

Vedi anche