SessionIDManager.CreateSessionID(HttpContext) Metoda
Definice
Důležité
Některé informace platí pro předběžně vydaný produkt, který se může zásadně změnit, než ho výrobce nebo autor vydá. Microsoft neposkytuje žádné záruky, výslovné ani předpokládané, týkající se zde uváděných informací.
Vytvoří jedinečný identifikátor relace pro relaci.
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
Parametry
- context
- HttpContext
Aktuální HttpContext objekt, který odkazuje na serverové objekty používané ke zpracování požadavků HTTP (například vlastnosti Request a Response požadavky HTTP).
Návraty
Jedinečný identifikátor relace.
Implementuje
Příklady
Následující příklad kódu ukazuje třídu, která dědí SessionIDManager třídu a přepíše CreateSessionID a Validate metody pomocí metod, které poskytují a ověřují Guid jako 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
Chcete-li použít vlastní třídu předvedenou v tomto příkladu, nakonfigurujte atribut sessionIDManagerType elementu sessionState (ASP.NET Nastavení Schema), jak je znázorněno v následujícím příkladu.
<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"
/>
Poznámky
Tato metoda není určena k zavolání z kódu aplikace.
Metoda CreateSessionID vrátí jedinečný identifikátor relace, který je náhodně vygenerované číslo zakódované do řetězce 24 znaků, který se skládá z malých písmen z až z a čísla od 0 do 5.
Poznámky pro dědice
Vlastní identifikátor relace, který se má použít ve stavu relace ASP.NET, můžete zadat vytvořením třídy, která dědí třídu a přepisuje SessionIDManager CreateSessionID(HttpContext) metody Validate(String) vlastními implementacemi. Pokud vaše vlastní ID relace nesplňuje omezení znaků vynucená výchozí implementací Validate(String) metody, měli byste metodu Validate(String) přepsat, aby se zajistilo ověření vlastního identifikátoru relace. V tomto případě třída zajistí, SessionIDManager aby váš vlastní identifikátor relace byl zakódován v odpovědi HTTP a adresa URL dekódovaná z požadavku HTTP pomocí Encode(String) metod a Decode(String) metod.