Поделиться через


SessionIDManager.CreateSessionID(HttpContext) Метод

Определение

Создает уникальный идентификатор сеанса.

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

Параметры

context
HttpContext

Текущий объект HttpContext, содержащий ссылки на серверные объекты, используемые для обработки HTTP-запросов (например, свойства Request и Response).

Возвращаемое значение

Уникальный идентификатор сеанса.

Реализации

Примеры

В следующем примере кода показан класс, который наследует SessionIDManager класс и переопределяет CreateSessionID методы и Validate с помощью методов, которые предоставляют и проверяют как SessionIDGuid .

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

Чтобы использовать пользовательский класс, показанный в этом примере, настройте атрибут sessionIDManagerType элемента sessionState (ASP.NET Settings Schema), как показано в следующем примере.

<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"
/>

Комментарии

Этот метод не предназначен для вызова из кода приложения.

Метод CreateSessionID возвращает уникальный идентификатор сеанса, который представляет собой случайно сгенерированное число, закодированное в 24-значную строку, состоящую из символов нижнего регистра от до z и чисел от 0 до 5.

Примечания для тех, кто наследует этот метод

Вы можете указать пользовательский идентификатор сеанса, который будет использоваться для ASP.NET состояния сеанса, создав класс, наследующий SessionIDManager класс, и переопределив CreateSessionID(HttpContext) методы и Validate(String) с помощью собственных пользовательских реализаций. Если идентификатор пользовательского сеанса не соответствует ограничениям символов, применяемым реализацией Validate(String) метода по умолчанию, необходимо переопределить Validate(String) метод, чтобы обеспечить проверку пользовательского идентификатора сеанса. В этом случае класс гарантирует, что идентификатор пользовательского сеанса — это URL-адрес, SessionIDManager закодированный в HTTP-ответе, и URL-адрес, декодированный из HTTP-запроса с помощью Encode(String) методов и Decode(String) соответственно.

Применяется к

См. также раздел