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) соответственно.