SessionIDManager.CreateSessionID(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.
Cria um identificador único de sessão para a sessão.
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
Parâmetros
- context
- HttpContext
O objeto atual HttpContext que faz referência a objetos do servidor usados para processar pedidos HTTP (por exemplo, as Request propriedades e).Response
Devoluções
Um identificador único de sessão.
Implementações
Exemplos
O seguinte exemplo de código mostra uma classe que herda a SessionIDManager classe e sobrepõe os CreateSessionID métodos e Validate com métodos que fornecem e validam a Guid como o 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
Para usar a classe personalizada demonstrada neste exemplo, configure o atributo sessionIDManagerType do elemento sessionState (ASP.NET Settings Schema), como mostrado no exemplo seguinte.
<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"
/>
Observações
Este método não se destina a ser chamado a partir do código da aplicação.
O CreateSessionID método devolve um identificador de sessão único que é um número gerado aleatoriamente codificado numa cadeia de 24 caracteres composta por caracteres minúsculos de a a z e números de 0 a 5.
Notas para Herdeiros
Pode fornecer um identificador de sessão personalizado para ser usado pelo estado ASP.NET sessão criando uma classe que herde a classe SessionIDManager e sobrescrevendo os métodos CreateSessionID(HttpContext) e Validate(String) com as suas próprias implementações personalizadas. Se o seu ID de sessão personalizado não cumprir as restrições de caracteres impostas pela implementação padrão do Validate(String) método, deve sobrescrever o Validate(String) método para validar o identificador de sessão personalizado. Neste caso, a SessionIDManager classe assegurará que o seu identificador de sessão personalizado está codificado na resposta HTTP e URL decodificado a partir do pedido HTTP usando os Encode(String) métodos e Decode(String) , respetivamente.